JavaScript中,this关键字的指向是动态变化的,它依赖于函数的调用方式。理解this的指向是JavaScript编程中的一项重要技能,因为它直接影响到函数内部访问到的对象。下面详细解释几种常见的this指向情况:
在全局作用域(浏览器中的全局对象是window,Node.js中的全局对象是global)中,this指向全局对象。
console.log(this===window); // 在浏览器中输出 true
console.log(this.document !==undefined); // 验证this指向全局对象
在普通函数调用时(非严格模式下),this指向全局对象(浏览器中是window,Node.js中是global)。在严格模式('use strict';)下,this是undefined。
function test() {
console.log(this===window); // 非严格模式下为 true
}
test();
function strictTest() {
'use strict';
console.log(this===undefined); // 严格模式下为 true
}
strictTest();
当一个函数被保存为某个对象的属性时,我们称之为方法。在方法调用中,this指向调用该方法的对象。
const obj={
method: function() {
console.log(this===obj); // 输出 true
}
};
obj.method();
在构造函数中,this指向新创建的对象实例。
function Car(make, model) {
this.make=make;
this.model=model;
}
const myCar=new Car('Ford', 'Mustang');
console.log(myCar.make); // 输出 Ford
箭头函数不绑定自己的this,它会捕获其所在上下文的this值,作为自己的this值。
const obj={
method: function() {
return ()=> {
console.log(this===obj); // 输出 true
};
}
};
const func=obj.method();
func();
使用call()、apply()和bind()方法可以显式设置函数执行时this的指向。
这些方法都允许你调用一个函数,并显式地设置函数体内this的值,call和apply会立即执行函数,而bind会返回一个新的函数,这个新函数在被调用时,this会被设置为bind的第一个参数,而其余参数将作为新函数的参数,供调用时使用。
call()方法调用一个函数,其具有一个指定的this值和分别提供的参数(参数的列表)。
function greet(greeting, punctuation) {
console.log(this.name + ' says, ' + greeting + punctuation);
}
const person={
name: 'Alice'
};
// 使用call()显式设置this指向person对象
greet.call(person, 'Hello', '!');
// 输出: Alice says, Hello!
apply()方法调用一个函数,其具有一个指定的this值,以及作为一个数组(或类数组对象)提供的参数。
function greet(greeting, punctuation) {
console.log(this.name + ' says, ' + greeting + punctuation);
}
const person={
name: 'Bob'
};
// 使用apply()显式设置this指向person对象,参数作为数组传递
greet.apply(person, ['Hi', '.']);
// 输出: Bob says, Hi.
bind()方法创建一个新的函数,在bind()被调用时,这个新函数的this被指定为bind()的第一个参数,而其余参数将作为新函数的参数,供调用时使用。
function greet(greeting, punctuation) {
console.log(this.name + ' says, ' + greeting + punctuation);
}
const person={
name: 'Charlie'
};
// 使用bind()创建一个新函数,其this指向person对象
const greetCharlie=greet.bind(person, 'Hey', '!');
// 调用新函数
greetCharlie();
// 输出: Charlie says, Hey!
// 注意:bind()不会立即执行函数,而是返回一个新函数
理解这些this的指向规则,对于编写清晰、可维护的JavaScript代码至关重要。
HTML中,列表、引用和代码是常用的结构,它们有助于组织内容,突出显示特定信息,并提高网页的可读性和功能性。本文将详细介绍这些元素的使用方法和实例。
列表是组织项目或信息点的一种方式。在HTML中,有两种主要类型的列表:有序列表和无序列表。
有序列表使用<ol>标签创建,列表中的每个项目使用<li>(列表项)标签标记。有序列表通常用于表示有特定顺序的步骤或排名。
<ol>
<li>开启电脑。</li>
<li>打开浏览器。</li>
<li>访问网站。</li>
</ol>
在这个例子中,步骤按照顺序排列,用户应该按照列表的顺序执行。
无序列表使用<ul>标签创建,同样使用<li>标签来定义列表项。无序列表适用于没有特定顺序要求的项目列表。
<ul>
<li>苹果</li>
<li>香蕉</li>
<li>橘子</li>
</ul>
这个例子中的水果列表没有特定的顺序要求。
引用用于表示页面上的文本是从其他来源引用的。在HTML中,<blockquote>标签用于定义长引用,而<q>标签用于定义短引用。
长引用通常用于引用段落长度的文本。它通常会缩进,并且可以包含引用的来源信息。
<blockquote cite="http://example.com/quote-source">
<p>这是一个长引用的实例,通常用于引用段落文本。引用的文本应该保持原作的语境和意义。</p>
<footer>— 引用自 <cite>《引用来源的书名》</cite></footer>
</blockquote>
短引用用于行内文本,它通常不会改变文本的布局。
<p>正如某人所说:<q>知识就是力量。</q></p>
在网页中展示代码片段时,HTML提供了<code>标签用于标记代码。对于多行代码或需要保持格式的代码,可以使用<pre>标签。
单行代码用于展示简短的代码或命令。
<p>要添加一个段落,你可以使用<code><p>...</p></code>标签。</p>
多行代码或需要保持原始格式的代码使用<pre>和<code>标签组合使用。
<pre><code>function greet(name) {
return 'Hello, ' + name + '!';
}</code></pre>
在这个例子中,<pre>标签保持了代码的格式,而<code>标签表示文本是代码。
HTML中的列表、引用和代码是构建清晰、有组织的网页内容的重要工具。列表帮助用户理解信息的结构,引用增加了内容的可信度,而代码的正确展示对于教学和技术文章来说至关重要。通过熟练运用这些元素,你可以提高网页的专业性,使内容对用户更加友好和易于理解。
.标签语义化
提到标签,很多刚入门前端开发的人,肯定都会很纳闷,这么多HTML标签我如何记住呢?我又应该根据什么依据去正确使用它呢?其实这样的问题,我刚开始和大家一样苦闷,但是在我学习Web页面开发的过程中,然后不断的积累,不断的总结,发现要想记住HTML标签以及怎样更好的去使用这些标签,需要做到以下三点:
第一点:不要死记硬背,没意义,只需要记住常用的哪几个足矣。
第二点:根据内容选择使用HTML标签,什么意思呢?见下文分解。
第三点:遵循W3C的规范。
首先,第一点咱们就不用说,不让死记硬背,就是要多写页面,多敲代码,久而久之孰能生巧,巧能生花,慢慢的你就能记住这些标签了,而且在开发页面的过程中,你们会发现,咱们最常用的也就是那么几个而已。
其次,第二点根据内容选择使用HTML标签,这一点非常关键,因为你掌握了这一点,你能很好地去使用HTML标签,并且能让页面变得很优质,这也会提高你网页被搜索引擎收录。
最后,也就是第三点,这一点自然不用怀疑,如果要想让页面更好的在不同的浏览器中呈现出一致的效果,那么必须遵循W3C的规范。
说了这么多,只是一些学习需要注意的问题,下面才是真正解开怎样去使用和记住标签这个谜团的方法。
我们在使用标签的过程中,大家会发现类似的标签,比如标题标签(h1-h6)、p(段落标签)、a(超链接标签)以及图片标签(img)等,通过这些标签的名称,咱们是不是不难理解吧,很直观的就知道这些标签该怎么,用于何处。而这些名称的含义就是我们所说的标签语义化。随着智能手机的出来,移动Web都是通过H5去开发页面,而H5中的HTML标签就比之前版本的HTML标签更加具有语义化。
那么什么是标签语义化呢?所谓的标签语义化,指的就是标签所代表的含义。咱们可以通过标签的含义,正确地去使用它。
标签语义化的作用:
如下图所示,通过使用语义化标签和没使用任何标签,就能直观感受到语义化标签的好处。
普通的文本和使用语义化标签后的效果对比图
那么如何去判断一个页面中,语义化是否良好呢?很简单,直接扒掉CSS这层漂亮的衣服,当我们把CSS去掉后,如果页面中的结构依然组织有序,并且有良好的可读性,那么它就是非常良好的。
如何去使用这些标签呢?首先根据内容确定语义化的标签,其次再根据呈现需求,使用CSS样式。因此HTML标签并非通过死记硬背,而是通过在使用的过程中,利用HTML标签的语义化去记忆。如下图所示,通过使用语义化标签,瞬间就能把普通的文本,以更清晰的结构呈现出来。
使用语义化的普通文本,变得更为结构清晰
2.常用标签分类汇总
通常我们常见的标签有标题标签、段落标签、水平线标签、换行标签以及div和span标签,这些标签又被统称为排版标签。
在开发中,排版标签主要是和CSS搭配使用,主要是用于显示网页的整体结构,也是网页布局中常用的标签。下面我一一了解一下。
排版标签:
【1】标题标签(h1-h6)
标题标签的使用
呈现的效果如下:
呈现的效果
一句话总结:使用了标题标签的文字会加粗,会根据级别显示文字的大小,并且一行只能放一个标题。
【2】段落标签(p)
p标签语法格式
【3】水平线标签(hr)
【4】换行标签(br)
文本
呈现效果:
使用br标签后的效果
【5】div和span标签
最后给大家来一个完美的总结:
排版标签的汇总
难道这就完了吗?咱们的标签就只有这些常用的吗?那当然不是,咱们接下来再看我们的文本格式化标签。
文本格式化标签
文本格式化标签的作用:通常文本格式化标签主要用于网页中文字样式的设置,比如字体加粗、斜体或下划线等效果,当然后期也会通过CSS样式来实现,会更加完美。
常见的文本格式化标签如下:
文本格式化标签
它们分别的区别:
我么网页中除了排版标签、文本格式化标签,当然还少不了图片标签(img),通过图片的展示,会让整个页面更加的生动形象。那么下面再来看一下这个标签吧。
图片标签(img)
img标签属性
标签属性的特点:
图片标签属性使用
链接标签
a标签的常见属性
提示:
内部链接地址
注释标签
注释标签
好了,各位小伙伴,今天我就给大家分享到这儿了,希望我给大家总结的内容,能帮到正在浏览我这篇内容的前端开发者,也希望你们有所收获。如果喜欢的,可以点击关注,会继续给大家分享更多的内容。
*请认真填写需求信息,我们会在24小时内与您取得联系。