(点击图片进入关卡)
使用单个事件侦听器来处理多个元素。
简介
当一个事件函数被调用时,它会添加一个叫做 this 的变量。
当与 jQuery 对象一起使用时,它会选择它被调用的特定元素。
默认代码
<!-- 找到哪个元素被选中是有可能的。 -->
<!-- 在事件函数中使用$(this)就可以做到这一点。 -->
<!-- var elm = $(this)将elm设置为单击元素。 -->
<script>
li = $("li");
function toggleStriked() {
$(this).toggleClass("striked");
}
li.on("click", toggleStriked);
h2 = $("h2"); // 这将h2设置为所有h2元素。
function toggleBold() {
// $()也接受'this'作为参数。
// 'this',当一个事件函数是...
// …事件的具体目标!
// 以“toggleStriked”为例。
// 在点击的h2上切换类“粗体”:
}
// 当任何h2被点击时,执行“toggleBold”。
h2.on("click", toggleBold);
</script>
<style>
.bold {
font-weight:bold;
font-size:xx-large;
}
.striked {
text-decoration:line-through;
}
li {
cursor: pointer;
font-size:large;
}
</style>
<h1>美好的清单</h1>
<h2>女巫的购物清单</h2>
<ul>
<li>蝾螈的眼睛</li>
<li>蒲公英的乳汁</li>
<li>有獠牙的鳟鱼</li>
<li>燕麦</li>
<li>独角兽角粉末</li>
</ul>
<h2>毒蕈炖煮食谱</h2>
<ol>
<li>把锅烧开。</li>
<li>添加蝾螈的眼睛。</li>
<li>用木勺搅拌。</li>
<li>加入脱水的毒蕈。</li>
<li>享受!</li>
</ol>
概览
#$(this)
this 是JavaScript中的一个特殊关键字。 在jQuery函数 $ 内,它会选择事件函数的具体目标。
当使用事件时, $(this) 是一个非常强大的工具!
function colorClicked() {
var element = $(this); // this是被点击的特定<li>
element.css("background-color", "red"); // 这只会将被点击的特定元素着色
}
var listItem = $("li");
listItem.on("click", colorClicked);
充满事件的选择器 解法
<!-- 找到哪个元素被选中是有可能的。 -->
<!-- 在事件函数中使用$(this)就可以做到这一点。 -->
<!-- var elm = $(this)将elm设置为单击元素。 -->
<script>
li = $("li");
function toggleStriked() {
$(this).toggleClass("striked");
}
li.on("click", toggleStriked);
h2 = $("h2"); // 这将h2设置为所有h2元素。
function toggleBold() {
// $()也接受'this'作为参数。
// 'this',当一个事件函数是...
// …事件的具体目标!
// 以“toggleStriked”为例。
// 在点击的h2上切换类“粗体”:
$(this).toggleClass("bold");
}
// 当任何h2被点击时,执行“toggleBold”。
h2.on("click", toggleBold);
</script>
<style>
.bold {
font-weight:bold;
font-size:xx-large;
}
.striked {
text-decoration:line-through;
}
li {
cursor: pointer;
font-size:large;
}
</style>
<h1>美好的清单</h1>
<h2>女巫的购物清单</h2>
<ul>
<li>蝾螈的眼睛</li>
<li>蒲公英的乳汁</li>
<li>有獠牙的鳟鱼</li>
<li>燕麦</li>
<li>独角兽角粉末</li>
</ul>
<h2>毒蕈炖煮食谱</h2>
<ol>
<li>把锅烧开。</li>
<li>添加蝾螈的眼睛。</li>
<li>用木勺搅拌。</li>
<li>加入脱水的毒蕈。</li>
<li>享受!</li>
</ol>
本攻略发于极客战记官方教学栏目,原文地址为:
https://codecombat.163.com/news/jikezhanji-chongmanshijiandexuanzeqi