点击每个li输出里面的内容(前端很常问的面试题之一)
点击每个li输出里面的内容(前端很常问的面试题之一)
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>click事件的几种写法</title>
</head>
<body>
    <ul id="parent">
        <li>第1个</li>
        <li>第2个</li>
        <li>第3个</li>
        <li>第4个</li>
        <li>第5个</li>
        <li>第6个</li>
        <li>第7个</li>
    </ul>
    <script>
        var ul = document.getElementById('parent');
        var li = ul.getElementsByTagName('li');
    </script>
</body>
</html>
这是一道很常见的前端面试题,让你点击每个li输出里面相应的内容,今天就来给大家放上我最常用的三种方法,并解释里面用到的知识点~
第一种
function Closure() {
    for(var i = 0; i < li.length; i++) {
        (function(j){
            li[j].onclick = function() {
                console.log(li[j].innerHTML);
            }
        })(i);
    }
}
第一种方法是使用吃掉闭包的方法,因为onclick的异步执行导致只能输出第li.length个li内部的文字,但因为并没有第li.length个li所以代码并不会输出(可以去掉代码内部的立即执行函数进行实验)。加入立即执行函数就延长了click事件的活动对象,强制使代码符合预期。
关于闭包
第二种
function This() {
    for(var j = 0; j < li.length; j++) {
        li[j].onclick = function() {
            console.log(this.innerHTML);
        }
    }
}
第二种方法是使用this的原理,因为对于this的隐式绑定来说,this指向的是调用位置上的包含对象,也就是你点击的那个li[i]。通过this的指向就可以轻松得到我们想要的答案了~
关于this
第三种
function eve() {
    ul.onclick = function(eve) {
        if(eve.target.tagName.toLowerCase() === 'li') {
            console.log(eve.target.innerHTML);
        }
    }
}
第三种使用的是事件代理以及event事件的内置属性来达到效果。事件代理不必再细说了,就是因为浏览器的事件冒泡机制将事件绑定在发生事件的上级元素上。因为event事件有很多属性及方法,在这里插播列举一下这些方法吧
| 属性/方法 | 类型 | 说明 | 
|---|---|---|
| bubbles | Boolean | 表示事件是否冒泡 | 
| cancelable | Boolean | 表示是否可以取消事件的默认行为 | 
| currentTarget | Element | 表示事件处理程序当前正在处理的那个元素 | 
| defaultPrevented | Boolean | 为true表示已调用了preventDefault() | 
| detail | Integer | 与事件相关的细节信息 | 
| eventPhase | Integer | 调用事件处理程序的阶段:1表示捕获阶段,2表示‘处于目标’,3表示冒泡阶段 | 
| preventDefault() | Function | 取消事件的默认行为 | 
| stopImmediatePropagation() | Function | 取消事件的进一步捕获或者冒泡,同时阻止任何事件处理程序被调用 | 
| stopPropagation() | Function | 取消事件的进一步捕获或者冒泡 | 
| target | Element | 事件的目标元素 | 
| trusted | Boolean | 为true表示事件是浏览器生成的,为false表示事件由开发人员通过JavaScript创建的 | 
| type | String | 被触发事件的类型 | 
| view | AbstractView | 与事件相关的抽象视图 | 
在这个需求中我们只需要使用eve.target这个属性就能获得你点击的目标元素。if的判断是避免绑定事件的元素下级还有其他不是li的元素也会执行这个代码。
好了,这个简单的题目就讲解到这里了,不同的面试对这道题会有一定程度的改变,不过只要理解了相关的知识就不怕应付千变万化啦~
点击每个li输出里面的内容(前端很常问的面试题之一)的更多相关文章
- ASP.NET压缩输出的HTML内容
		
在ASP.NET中,怎么压缩输出的HTML内容,怎么替换HTML中的换行符,空白,TAB等符号呢? 1.新建一个基类,继承自System.Web.UI.Page,代码如下: using System. ...
 - 点击每个li节点,都弹出其文本值及修改
		
点击每个li节点,都弹出其文本值 1,获取所有的li节点 var liNodes=document.GetElementsByTagName("li"); 2,使用for循环进行遍 ...
 - jq获取当前点击的li是ul中的第几个?
		
<script> var navulsize = $('.navul li').size(); var navulwidth = $('.navul li').wid ...
 - 点击li,点击的li添加class,其余去掉class
		
点击li,点击的li添加class,其余去掉class <script type="text/javascript"> $(function () { var liob ...
 - WCF 在VS中,添加服务引用,地址输入http://ip/Service.svc,点击前往,提示错误,内容如下:
		
WCF的service端的webconfig如下: <?xml version="1.0"?> <configuration> <system.ser ...
 - XML解析之sax解析案例(一)读取contact.xml文件,完整输出文档内容
		
一.新建Demo2类: import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXPar ...
 - 004 作业二(单击弹跳li节点的每个文本节点的值;点击每个 li 节点, 若 li 节点的文本值没有 ^^ 开头, 加上,有,则去除)
		
1.需求 点击每个 li 节点, 都弹出其文本值 2.程序 <!DOCTYPE html> <html> <head> <meta charset=" ...
 - Linux nl --让输出的文件内容自动加上行号
		
nl命令在linux系统中用来计算文件中行号.nl 可以将输出的文件内容自动的加上行号!其默认的结果与 cat -n 有点不太一样, nl 可以将行号做比较多的显示设计,包括位数与是否自动补齐 0 等 ...
 - 鼠标点击input框后里面的内容就消失
		
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
 
随机推荐
- 【bzoj2456】 mode
			
http://www.lydsy.com/JudgeOnline/problem.php?id=2456 (题目链接) 只看了一眼,直觉便告诉我这是水题.于是跟某码农打赌说10分钟做出来叫爸爸,结果输 ...
 - eclipse安装插件的方法(简单、ERMaster插件安装)
			
ERMaster插件:https://sourceforge.net/projects/ermaster/ 链接:http://pan.baidu.com/s/1o7UWLMa 密码:wkax 可以编 ...
 - Uva1398 Meteor
			
扫描线法. 将流星出现在相机里的时间转化成线段,离散化端点后,扫描何时出现的流星最多.注意边界的不算,所以要先减右端点再加左端点 /*By SilverN*/ #include<iostream ...
 - TCP/IP详解 笔记十三
			
TCP协议(一) 概述 特点 1, 面向连接可靠的字节流服务 2, 只有两方通信,不能用于广播或多播 3, 应用数据被TCP分隔为最合适发送的数据段,传给IP协议栈 4, 发送端并启动定时器, ...
 - HDU 1710 Binary Tree Traversals(二叉树遍历)
			
传送门 Description A binary tree is a finite set of vertices that is either empty or consists of a root ...
 - iOS评分(给个好评)
			
id 721996244 可以测试 NSString *str = [NSString stringWithFormat:@"itms-apps://itunes.apple.com/app ...
 - python列表、元组、字典(四)
			
列表 如:[11,22,33,44,44].['TangXiaoyue', 'bruce tang'] 每个列表都具备如下功能: class list(object): ""&qu ...
 - zabbix监控系列(3)之zabbix触发器格式配置
			
前言 今天公司线上环境新添一个监控项,监控 一些日志的是否出现错误,有错误就及时报警,那么问题来了 ,报警必须告诉我们哪个日志有错误,这样才能够快速定位到哪个日志有问题. 配置 zabbix-agen ...
 - SQL Server 2012 启动
			
1. 启动 SQL Server Management studio 2. 选择登录模式 Server name: "." 代表本地的数据库 Authertication: ...
 - Eclipse自动补全+常用快捷键
			
一,Eclipse自动补全增强方法 在Eclipse中,从Window -> preferences -> Java -> Editor -> Content assist - ...