前端面试题【js动态创建节点、怎么阻止冒泡事件、怎么阻止默认事件、什么是深拷贝,什么是浅拷贝、js造成内存泄漏的操作有哪些等】

简介: 前端面试题【js动态创建节点、怎么阻止冒泡事件、怎么阻止默认事件、什么是深拷贝,什么是浅拷贝、js造成内存泄漏的操作有哪些等】

JS动态创建节点

问题 1:

请补全JavaScript函数,根据参数数组创建li元素。

要求:

1、li元素的个数和数组的长度一样

2、li元素的内容是数组中的每个元素

3.、将创建的所有li元素插入到ul中

解答:

<html>
    <head>
        <meta charset=utf-8>
    </head>
    <body>
        <ul></ul>
    </body>
    <script type="text/javascript">
        function createLi(array) {
            var ul = document.querySelector('ul')
            for(let i=0 ; i<array.length ; i++) {
                let li = document.createElement('li')
                li.innerHTML = array[i]
                ul.appendChild(li)
        }
}
    </script>
</html>

微信图片_20220927124938.png总结:

1、核心步骤:

1)获取ul标签元素

2)创建li标签元素

3)设置li标签元素内容

4)将li标签元素插入到ul标签元素内

在JavaScript中获取页面某个元素的方法有很多,根据题目内容选择document.querySelector()方法是最优的,它可以获取当前页面首个目标标签元素。接下来通过循环遍历数组,并且在每一个循环体中通过document.createElement()方法创建li标签,再通过innerHTML或innerText设置li标签内容,最后通过appendChild()方法将li添加在ul中。


除此之外,还有很多方法,例如:

function createLi(array){
    let ul = document.querySelector('ul');
    array.forEach(function(v,i,a){
      ul.insertAdjacentHTML('beforeend',`<li>${v}</li>`)
    })
  }

根据ID获取元素

问题 2:

请补全JavaScript函数,根据id获取html模块中ul标签下第二个li元素并返回。

解答:

function getLI(id){
    // 补全代码
    return document.getElementById('li')
}

微信图片_20220927125048.png总结:


1、这个很简单就不多说了。

获取元素的几种方法:

1、根据id获取元素;


document.getElementById(“id属性的值”);


2、根据标签名字获取元素;


document.getElementsByTagName(“标签的名字”);


3、根据name属性的值获取元素;


document.getElementsByName(“name属性的值”);


4、根据类样式的名字获取元素;


document.getElementsByClassName(“类样式的名字”);


5、根据选择器获取元素。


1、document.querySelector(“选择器”);

2、document.querySelectorAll(“选择器”);

JS修改元素内容

问题 3:

请补全JavaScript函数,将类为"box"的div元素内容修改为"欢迎来到牛客网"。题


解答:

<html>
    <head>
        <meta charset=utf-8>
    </head>
    <body>
        <div class='box'></div>
    </body>
    <script type="text/javascript">
        function modifyText(){
            // 补全代码
            var div = document.getElementsByClassName('box');
            div[0].innerHTML = "欢迎来到牛客网";
        }
    </script>
</html>

微信图片_20220927125126.png总结:

1、核心步骤。

1)获取div(块级)标签元素。

2)修改div(块级)标签内容。innerHTML


在JavaScript中,获取一个标签元素的方法有很多,例如:

1、document.querySelector()获取页面中首个div标签元素。document.querySelectorall()是获得所有的div,太泛了,故此处不可以。

2、document.getElementsByClassName()获取div标签元素。

3、document.getElementsByTagName(“box”)[0];获取div标签元素。


注意: document.getElementsByClassName()可以获取当前页面所有目标类名的元素标签,仅需选取首个([0])数组元素即可。再通过innerHTML或innerText修改该标签元素内容。

阻止冒泡事件

问题 4:

请补全JavaScript函数,要求在点击li元素的时候不触发ul的事件。

注意:需要自行获取li元素。


解答:

<html>
    <head>
        <meta charset=utf-8>
    </head>
    <body>
        <ul>
            <li>nowcoder</li>
        </ul>
    </body>
    <script type="text/javascript">
        // 补全代码
        let ans = function () {
        let li = document.querySelector('li')
        li.addEventListener('click', function (e) { //点击无效
            if (e && e.stopPropagation) {
                //支持W3C的浏览器
                e.stopPropagation()
            } else {
               //IE中
                window.event.cancelBubble = true;
            }
        })
    }
    ans.call(this)
    </script>
</html>

微信图片_20220927125209.png总结:

1、阻止冒泡事件:stopPropagation()函数。

2、调用event.stopPropagation()方法,该方法终止事件在传播过程的捕获、目标处理或起泡阶段进一步传播。


Event对象代表事件的状态,比如事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态等。事件通常与函数结合使用,函数不会在事件发生前执行!

阻止默认事件

问题 5:

请补全JavaScript函数,要求在点击id为"checkbox"的复选框时不会取消勾选状态。

注意:需要自行获取input元素。


解答:

<html>
    <head>
        <meta charset=utf-8>
    </head>
    <body>
        <form>
            <label>牛客会陪伴大家</label>
            <input id="checkbox" type="checkbox" checked />
        </form>
    </body>
    <script type="text/javascript">
        // 补全代码
        var a=document.querySelector('#checkbox');
        a.onclick=function(){
            if(a.checked){
            }else{a.checked=true;}
        }
    </script>
</html>

微信图片_20220927125248.png总结:

上面是一个简单的暴力拆解,核心步骤

1)通过id等于checkbox获取input元素。

2)监听,点击判断。

3)如果被选中则~~,否则则为true。


什么是深拷贝,什么是浅拷贝,二者有什么区别,平时改怎么区分呢?

js中不同类型存放的位置不同

看完上面的例子你可能还是晕晕的,那么来详细的看看什么是深拷贝,什么是浅拷贝吧。

微信图片_20220927125534.png


js中的基础类型:string,number,boolean,null,undefined,symbol

js中的引用类型:Object


基础类型:是按照值 存放在栈中,占用的内存空间的大小是确定的,并由系统自动分配和自动释放。

引用类型: 是按照地址 存在堆中,将存放在栈内存中的地址赋值给接收的变量。当我们想要访问引用类型的值的时候,需要先从栈中获得对象的地址指针,然后,在通过地址指针找到堆中的所需要的数据。

需要注意的是,js和Java一样也有栈内存和堆内存,基础类型存放在栈内存中,引用类型存放在堆内存中。微信图片_20220927125550.png

深拷贝与浅拷贝的区别

深拷贝:主要是将另一个对象的属性值拷贝过来之后,另一个对象的属性值并不受到影响,因为此时它自己在堆中开辟了自己的内存区域,不受外界干扰。

浅拷贝:主要拷贝的是对象的引用值,当改变对象的值,另一个对象的值也会发生变化。


SO,需要注意的是。如果在对对象进行赋值时,如果不希望共享对象,那么就要进行深拷贝。


常用的深拷贝方法:

1、序列化和反序列

JSON.parse( JSON.stringify() ) 序列化和反序列

♻♻2、assign

es6新增的方法,可用于对象合并,将源对象的所有可枚举属性,复制到目标对象上。

Object.assign(target, source1, source2)

注意:当对象中只有一级属性,没有二级属性的时候,此方法为深拷贝,
但是对象中有对象的时候,此方法,在二级属性以后就是浅拷贝

3、迭代递归方法

4、通过jQuery的extend方法实现深拷贝

5、lodash函数库实现深拷贝

let clone = cloneDeep(obj)

微信图片_20220927125248.png


目录
相关文章
|
3月前
|
JavaScript 前端开发 Java
避免 JavaScript 中的内存泄漏
【10月更文挑战第30天】避免JavaScript中的内存泄漏问题需要开发者对变量引用、事件监听器管理、DOM元素操作以及异步操作等方面有深入的理解和注意。通过遵循良好的编程实践和及时清理不再使用的资源,可以有效地减少内存泄漏的风险,提高JavaScript应用程序的性能和稳定性。
|
3月前
|
监控 JavaScript Java
Node.js中内存泄漏的检测方法
检测内存泄漏需要综合运用多种方法,并结合实际的应用场景和代码特点进行分析。及时发现和解决内存泄漏问题,可以提高应用的稳定性和性能,避免潜在的风险和故障。同时,不断学习和掌握内存管理的知识,也是有效预防内存泄漏的重要途径。
304 62
|
3月前
|
缓存 监控 JavaScript
避免在Node.js中出现内存泄漏
总之,避免内存泄漏需要在开发过程中保持谨慎和细心,遵循最佳实践,不断优化和改进代码。同时,定期进行内存管理的检查和维护也是非常重要的。通过采取这些措施,可以有效地降低 Node.js 应用中出现内存泄漏的风险,确保应用的稳定和性能。
|
3月前
|
Web App开发 JavaScript 前端开发
使用 Chrome 浏览器的内存分析工具来检测 JavaScript 中的内存泄漏
【10月更文挑战第25天】利用 Chrome 浏览器的内存分析工具,可以较为准确地检测 JavaScript 中的内存泄漏问题,并帮助我们找出潜在的泄漏点,以便采取相应的解决措施。
508 9
|
3月前
|
监控 JavaScript 前端开发
如何检测和解决 JavaScript 中内存泄漏问题
【10月更文挑战第25天】解决内存泄漏问题需要对代码有深入的理解和细致的排查。同时,不断优化和改进代码的结构和逻辑也是预防内存泄漏的重要措施。
93 6
|
3月前
|
JavaScript 前端开发 Java
JavaScript 中内存泄漏的几种常见情况
【10月更文挑战第25天】实际上还有许多其他的情况可能导致内存泄漏。为了避免内存泄漏,我们需要在开发过程中注意及时清理不再需要的资源,合理使用内存,并且定期检查内存使用情况,以确保程序的性能和稳定性
55 2
|
3月前
|
缓存 前端开发 JavaScript
"面试通关秘籍:深度解析浏览器面试必考问题,从重绘回流到事件委托,让你一举拿下前端 Offer!"
【10月更文挑战第23天】在前端开发面试中,浏览器相关知识是必考内容。本文总结了四个常见问题:浏览器渲染机制、重绘与回流、性能优化及事件委托。通过具体示例和对比分析,帮助求职者更好地理解和准备面试。掌握这些知识点,有助于提升面试表现和实际工作能力。
87 1
|
4月前
|
Android开发
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
|
4月前
|
Android开发
Android面试高频知识点(1) 图解 Android 事件分发机制
Android面试高频知识点(1) 图解 Android 事件分发机制
64 1
|
4月前
|
Web App开发 JavaScript 前端开发
前端Node.js面试题
前端Node.js面试题

热门文章

最新文章

  • 1
    【Java若依框架】RuoYi-Vue的前端和后端配置步骤和启动步骤
  • 2
    【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
  • 3
    【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
  • 4
    【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
  • 5
    详解智能编码在前端研发的创新应用
  • 6
    巧用通义灵码,提升前端研发效率
  • 7
    【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
  • 8
    智能编码在前端研发的创新应用
  • 9
    【04】flutter补打包流程的签名过程-APP安卓调试配置-结构化项目目录-完善注册相关页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程
  • 10
    抛弃node和vscode,如何用记事本开发出一个完整的vue前端项目