web前端面试题整理(程序篇)
来源:互联网 发布:html合并单元格编程题 编辑:程序博客网 时间:2024/05/22 00:50
1. var obj = {a : 1};(function (obj) { obj = {a : 2}; })(obj); //问obj的值会改变吗?
var obj = {a : 1};
(function (obj) {
obj = {a : 2};
})(obj);
//问obj的值会改变吗?
外部的obj不变.
因为匿名函数中obj传入参数等于是创建了一个局部变量obj,里面的obj指向了一个新的对象 .如果改成(function() { obj = {a : 2}; })(obj); 就会改变了
2. var obj = { a:1, func: function() {(function () { a=2; }(); }} ; obj.func() //obj中a的值会改变吗?匿名函数里的this指向的是什么?
var obj = {
a:1,
func: function() {
(function () {
a=2;
}();
}
} ;
obj.func();
//obj中a的值会改变吗? 匿名函数里的this指向的是什么?
obj里的a不会变.匿名函数里的this指向全局对象window. 这等于是给window加了一个名为a的属性
要改变obj中a的值 , 应当:
(function() {
this.a = 2
}).call(this);
(function() {
this.a = 2
}).call(this);
或者obj中定义
func: function() {
var self = this;
(function(){
self.a=2;
})();}
3. 要实现函数内每隔5秒调用自己这个函数,100次以后停止,怎么办?
(function(){
var index = 0;
function fn(){
if(index < 100){
index++;
setTimeout(function(){
fn();
},5000);
}
}
fn();
})();
4. 点击一个ul的五个li元素,分别弹出他们的序号,怎么做?
方法1 :
var oLi =document.getElementsByTagName('li');
for(var i=0;i<oLis.length; i++){
oLis[i].onclick = (function(j){
return function(){
alert(j);
}
})(i);
}
方法2:
var oLi =document.getElementsByTagName('li');
for(var i=0;i<oLi.length; i++){
(function(j){
oLi[j].onclick = function(){
alert(j);
};
})(i);
}
方法3:
var oLi =document.getElementsByTagName('li');
for(var i=0;i<oLi.length; i++){
oLi[i].index = i;
oLi[i].onclick = function(){
alert(this.index);
}
}
- web前端面试题整理后篇(程序篇)
- web前端面试题整理(程序篇)
- web前端面试题整理(HTML篇)
- web前端面试题整理(HTML篇)
- WEB前端面试题整理
- Web前端开发面试题整理(HTML+CSS+JavaScript)
- web前端面试题及答案整理(一)
- web前端面试题及答案整理(二)
- Web前端笔试面试题整理
- WEB前端面试题查询整理
- WEB前端面试题查询整理
- 前端面试题整理
- 前端面试题整理
- 前端面试题整理
- 前端面试题整理
- 前端面试题整理
- 前端面试题整理
- 前端面试题整理
- 树和二叉树
- 欢迎使用CSDN-markdown编辑器
- Jan 3rd - 新的一年,新的开始
- C++ 排序函数 sort(),qsort()的用法
- [LeetCode]406. Queue Reconstruction by Height 解题报告
- web前端面试题整理(程序篇)
- OpenGL环境搭建
- 《C++ API》
- 如何限制textarea标签文本长度
- 过年结束,开始上班
- 邮件名固定格式
- java 算法
- 《连载 - 物联网框架ServerSuperIO教程》- 15.数据持久化接口的使用。附:3.2发布与版本更新说明。
- 360X180度全景图预览插件Photo Sphere Viewer