本篇文章给大家谈谈javascript即时函数,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
1、Web前端工程师应该知道的JavaScript的10个难点!2、js中的常用函数3、请教一个简单的Javascript问题4、在地址栏如何直接使用javascript函数?
Web前端工程师应该知道的JavaScript的10个难点!
今天小编要跟大家分享的文章是关于Web前端工程师应该知道的JavaScript的10个难点。相信很多正在学习Web前端知识的小伙伴对于JavaScript存在很多疑问,为了帮助大家更好的学习Web前端知识,成为一名优秀的web前端工程师,今天小编为大家分享了这篇Web前端应该知道的JavaScript难点的问题,下面我们一起看一看吧!
1、立即执行函数
立即执行函数,即ImmediatelyInvokedFunctionExpression
(IIFE),正如它的名字,就是创建函数的同时立即执行。它没有绑定任何事件,也无需等待任何异步操作:
1.(function(){
2.
3.//代码
4.
5.//…
6.
7.})();
function(){}是一个匿名函数,包围它的一对括号将其转换为一个表达式,紧跟其后的一对括号调用了这个函数。立即执行函数也可以理解为立即调用一个匿名函数。立即执行函数最常见的应用场景就是:将var变量的作用域限制于你们函数内,这样可以避免命名冲突。
2、闭包
对于闭包(closure),当外部函数返回之后,内部函数依然可以访问外部函数的变量。
1.(function(){
2.
3.//代码
4.
5.//…
6.
7.})();
代码中,外部函数f1只执行了一次,变量N设为0,并将内部函数f2赋值给了变量result。由于外部函数f1已经执行完毕,其内部变量N应该在内存中被清除,然而事实并不是这样:我们每次调用result的时候,发现变量N一直在内存中,并且在累加。为什么呢?这就是闭包的神奇之处了!
3、使用闭包定义私有变量
通常,JavaScript开发者使用下划线作为私有变量的前缀。但是实际上,这些变量依然可以被访问和修改,并非真正的私有变量。这时,使用闭包可以定义真正的私有变量:
1.functionProduct(){
2.
3.varname;
4.
5.this.setName=function(value){
6.name=value;
7.};
8.
9.this.getName=function(){
10.returnname;
11.};
12.}
13.
14.varp=newProduct();
15.p.setName(“Fundebug”);
16.
17.console.log(p.name);//输出undefined
18.console.log(p.getName());//输出Fundebug
代码中,对象p的的name属性为私有属性,使用p.name不能直接访问。
4、prototype
每个JavaScript构造函数都有一个prototype属性,用于设置所有实例对象需要共享的属性和方法。prototype属性不能列举。JavaScript仅支持通过prototype属性进行继承属性和方法。
1.functionRectangle(x,y)
2.{
3.this._length=x;
4.this._breadth=y;
5.}
6.
7.Rectangle.prototype.getDimensions=function()
8.{
9.return{
10.length:this._length,
11.breadth:this._breadth
12.};
13.};
14.
15.varx=newRectangle(3,4);
16.vary=newRectangle(4,3);
17.
18.console.log(x.getDimensions());//{length:3,breadth:4}
19.console.log(y.getDimensions());//{length:4,breadth:3}
代码中,x和y都是构造函数Rectangle创建的对象实例,它们通过prototype继承了getDimensions方法。
5、模块化
JavaScript并非模块化编程语言,至少ES6落地之前都不是。然而对于一个复杂的Web应用,模块化编程是一个最基本的要求。这时,可以使用立即执行函数来实现模块化,正如很多JS库比如jQuery以及我们Fundebug都是这样实现的。
1.varmodule=(function(){
2.varN=5;
3.
4.functionprint(x){
5.console.log(“Theresultis:”+x);
6.}
7.
8.functionadd(a){
9.varx=a+N;
10.print(x);
11.}
12.
13.return{
14.description:”Thisisdescription”,
15.add:add
16.};
17.})();
18.
19.
20.console.log(module.description);//输出”thisisdescription”
21.
22.module.add(5);//输出“Theresultis:10”
所谓模块化,就是根据需要控制模块内属性与方法的可访问性,即私有或者公开。在代码中,module为一个独立的模块,N为其私有属性,print为其私有方法,decription为其公有属性,add为其共有方法。
6、变量提升
JavaScript会将所有变量和函数声明移动到它的作用域的最前面,这就是所谓的变量提升(Hoisting)。也就是说,无论你在什么地方声明变量和函数,解释器都会将它们移动到作用域的最前面。因此我们可以先使用变量和函数,而后声明它们。但是,仅仅是变量声明被提升了,而变量赋值不会被提升。如果你不明白这一点,有时则会出错:
1.console.log(y);//输出undefined
2.
3.y=2;//初始化y
上面的代码等价于下面的代码:
1.vary;//声明y
2.
3.console.log(y);//输出undefined
4.
5.y=2;//初始化y
为了避免BUG,开发者应该在每个作用域开始时声明变量和函数。
7、柯里化
柯里化,即Currying,可以是函数变得更加灵活。我们可以一次性传入多个参数调用它;也可以只传入一部分参数来调用它,让它返回一个函数去处理剩下的参数。
1.varadd=function(x){
2.returnfunction(y){
3.returnx+y;
4.};
5.};
6.
7.console.log(add(1)(1));//输出2
8.
9.varadd1=add(1);
10.console.log(add1(1));//输出2
11.
12.varadd10=add(10);
13.console.log(add10(1));//输出11
代码中,我们可以一次性传入2个1作为参数add(1)(1),也可以传入1个参数之后获取add1与add10函数,这样使用起来非常灵活。
8、apply,call与bind方法
JavaScript开发者有必要理解apply、call与bind方法的不同点。它们的共同点是第一个参数都是this,即函数运行时依赖的上下文。
三者之中,call方法是最简单的,它等价于指定this值调用函数:
1.varuser={
2.name:”RahulMhatre”,
3.whatIsYourName:function(){
4.console.log(this.name);
5.}
6.};
7.
8.user.whatIsYourName();//输出”RahulMhatre”,
9.
10.varuser2={
11.name:”NehaSampat”
12.};
13.
14.user.whatIsYourName.call(user2);//输出”NehaSampat”
·apply方法与call方法类似。两者唯一的不同点在于,apply方法使用数组指定参数,而call方法每个参数单独需要指定:
·apply(thisArg,[argsArray])
1.varuser={
2.greet:”Hello!”,
3.greetUser:function(userName){
4.console.log(this.greet+””+userName);
5.}
6.};
7.
8.vargreet1={
9.greet:”Hola”
10.};
11.
12.user.greetUser.call(greet1,”Rahul”);//输出”HolaRahul”
13.user.greetUser.apply(greet1,[“Rahul”]);//输出”HolaRahul”
使用bind方法,可以为函数绑定this值,然后作为一个新的函数返回:
1.varuser={
2.greet:”Hello!”,
3.greetUser:function(userName){
4.console.log(this.greet+””+userName);
5.}
6.};
7.
8.vargreetHola=user.greetUser.bind({greet:”Hola”});
9.vargreetBonjour=user.greetUser.bind({greet:”Bonjour”});
10.
11.greetHola(“Rahul”)//输出”HolaRahul”
12.greetBonjour(“Rahul”)//输出”BonjourRahul”
9、memoization
Memoization用于优化比较耗时的计算,通过将计算结果缓存到内存中,这样对于同样的输入值,下次只需要中内存中读取结果。
1.functionmemoizeFunction(func)
2.{
3.varcache={};
4.returnfunction()
5.{
6.varkey=arguments[0];
7.if(cache[key])
8.{
9.returncache[key];
10.}
11.else
12.{
13.varval=func.apply(this,arguments);
14.cache[key]=val;
15.returnval;
16.}
17.};
18.}
19.
20.
21.varfibonacci=memoizeFunction(function(n)
22.{
23.return(n===0||n===1)?n:fibonacci(n-1)+fibonacci(n-2);
24.});
25.
26.console.log(fibonacci(100));//输出354224848179262000000
27.console.log(fibonacci(100));//输出354224848179262000000
代码中,第2次计算fibonacci(100)则只需要在内存中直接读取结果。
10、函数重载
所谓函数重载(method
overloading),就是函数名称一样,但是输入输出不一样。或者说,允许某个函数有各种不同输入,根据不同的输入,返回不同的结果。凭直觉,函数重载可以通过if…else或者switch实现,这就不去管它了。jQuery之父John
Resig提出了一个非常巧(bian)妙(tai)的方法,利用了闭包。
从效果上来说,people对象的find方法允许3种不同的输入:
0个参数时,返回所有人名;1个参数时,根据firstName查找人名并返回;2个参数时,根据完整的名称查找人名并返回。
难点在于,people.find只能绑定一个函数,那它为何可以处理3种不同的输入呢?它不可能同时绑定3个函数find0,find1与find2啊!这里的关键在于old属性。
由addMethod函数的调用顺序可知,people.find最终绑定的是find2函数。然而,在绑定find2时,old为find1;同理,绑定find1时,old为find0。3个函数find0,find1与find2就这样通过闭包链接起来了。
根据addMethod的逻辑,当f.length与arguments.length不匹配时,就会去调用old,直到匹配为止。
1.functionaddMethod(object,name,f)
2.{
3.varold=object[name];
4.object[name]=function()
5.{
6.//f.length为函数定义时的参数个数
7.//arguments.length为函数调用时的参数个数
8.if(f.length===arguments.length)
9.{
10.returnf.apply(this,arguments);
11.}
12.elseif(typeofold===”function”)
13.{
14.returnold.apply(this,arguments);
15.}
16.};
17.}
18.
19.
20.//不传参数时,返回所有name
21.functionfind0()
22.{
23.returnthis.names;
24.}
25.
26.
27.//传一个参数时,返回firstName匹配的name
28.functionfind1(firstName)
29.{
30.varresult=[];
31.for(vari=0;i
32.{
33.if(this.names[i].indexOf(firstName)===0)
34.{
35.result.push(this.names[i]);
36.}
37.}
38.returnresult;
39.}
40.
41.
42.//传两个参数时,返回firstName和lastName都匹配的name
43.functionfind2(firstName,lastName)
44.{
45.varresult=[];
46.for(vari=0;i
47.{
48.if(this.names[i]===(firstName+””+lastName))
49.{
50.result.push(this.names[i]);
51.}
52.}
53.returnresult;
54.}
55.
56.
57.varpeople={
58.names:[“DeanEdwards”,”AlexRussell”,”DeanTom”]
59.};
60.
61.
62.addMethod(people,”find”,find0);
63.addMethod(people,”find”,find1);
64.addMethod(people,”find”,find2);
65.
66.
67.console.log(people.find());//输出[“DeanEdwards”,”AlexRussell”,”DeanTom”]
68.console.log(people.find(“Dean”));//输出[“DeanEdwards”,”DeanTom”]
69.console.log(people.find(“Dean”,”Edwards”));//输出[“DeanEdwards”]
以上就是小编今天为大家分享的关于Web前端工程师应该知道的JavaScript的10个难点。希望本篇文章能够对正在从事Web前端学习的小伙伴们有所帮助。想要了解更多web前端相关知识记得关注北大青鸟Web培训官网最后祝愿小伙伴们工作顺利!
原文链接:#/a/1190000010371988
js中的常用函数
下面介绍全页面刷新方法:有时候可能会用到
window.location.reload()刷新当前页面.
parent.location.reload()刷新父亲对象(用于框架)
opener.location.reload()刷新父窗口对象(用于单开窗口)
top.location.reload()刷新最顶端对象(用于多开窗口)
下面再介绍一些javascript基本函数
1.document.write(””);为 输出语句
2.js中的注释为//
3.传统的html文档顺序是:document-html-(head,body)
4.一个浏览器窗口中的dom顺序是:window-(navigator,screen,history,location,document)
5.得到表单中元素的名称和值:document.getelementbyid(”表单中元素的id号”).name(或value)
6.一个小写转大写的js: document.getelementbyid(”output”).value = document.getelementbyid (”input”).value.touppercase();
7.js中的值类型:string,number,boolean,null,object,function
8.js中的字符型转换成数值型:parseint(),parsefloat()
9.js中的数字转换成字符型:(””+变量)
10.js中的取字符串长度是:(length)
11.js中的字符与字符相连接使用+号.
12.js中的比较操作符有:==等于,!=不等于,,=,.=
13.js中声明变量使用:var来进行声明
14.js中的判断语句结构:if(condition){}else{}
15.js中的循环结构:for([initial expression];[condition];[upadte expression]) {inside loop}
16.循环中止的命令是:break
17.js中的函数定义:function functionname([parameter],…){statement[s]}
18.当文件中出现多个form表单时.可以用document.forms[0],document.forms[1]来代替.
19.窗口:打开窗口window.open(), 关闭一个窗口:window.close(), 窗口本身:self
20.状态栏的设置:window.status=”字符”;
21.弹出提示信息:window.alert(”字符”);
22.弹出确认框:window.confirm();
23.弹出输入提示框:window.prompt();
24.指定当前显示链接的位置:window.location.href=”url”
25.取出窗体中的所有表单的数量:document.forms.length
26.关闭文档的输出流:document.close();
27.字符串追加连接符:+=
28.创建一个文档元素:document.createelement(),document.createtextnode()
29.得到元素的方法:document.getelementbyid()
49.引用一个文件式的js:
50.指定在不支持脚本的浏览器显示的html:
51.当超链和onclick事件都有时,则老版本的浏览器转向a.html,否则转向b.html.例: dfsadf
52.js 的内建对象 有:array,boolean,date,error,evalerror,function,math,number,object,rangeerror,referenceerror,regexp,string,syntaxerror,typeerror,urierror
53.js中的换行:/n
54.窗口全屏大小:function fullscreen(){ this.moveto(0,0);this.outerwidth=screen.availwidth;this.outerheight=screen.availheight;}window.maximize=fullscreen;
55.js中的all代表其下层的全部元素
56.js中的焦点顺序:document.getelementbyid(”表单元素”).tabindex = 1
57.innerhtml的值是表单元素的值:如how are you,则innerhtml的值就是:how are you
58.innertext的值和上面的一样,只不过不会把em这种标记显示出来.
59.contenteditable可设置元素是否可被修改,iscontenteditable返回是否可修改的状态.
60.isdisabled判断是否为禁止状态.disabled设置禁止状态
61.length取得长度,返回整型数值
62.addbehavior()是一种js调用的外部函数文件其扩展名为.htc
63.window.focus()使当前的窗口在所有窗口之前.
64.blur()指失去焦点.与focus()相反.
65.select()指元素为选中状态.
66.防止用户对文本框中输入文本:onfocus=”this.blur()”
67.取出该元素在页面中出现的数量:document.all.tags(”div(或其它html标记符)”).length
68.js中分为两种窗体输出:模态和非模态.window.showmodaldialog(),window.showmodeless()
69.状态栏文字的设置:window.status=‘文字’,默认的状态栏文字设置:window.defaultstatus = ‘文字.’;
70.添加到收藏夹:external.addfavorite(””,”google”);
71.js中遇到脚本错误时不做任何操作:window.onerror = donothing; 指定错误句柄的语法为:window.onerror = handleerror;
72.js中指定当前打开窗口的父窗口:window.opener,支持opener.opener…的多重继续.
73.js中的self指的是当前的窗口
74.js中状态栏显示内容:window.status=”内容”
75.js中的top指的是框架集中最顶层的框架
76.js中关闭当前的窗口:window.close();
77.js中提出是否确认的框:if(confirm(”are you sure?”)){alert(”ok”);}else{alert(”not ok”);}
78.js中的窗口重定向:window.navigate(””);
79.js中的打印:window.print()
80.js中的提示输入框:window.prompt(”message”,”defaultreply”);
81.js中的窗口滚动条:window.scroll(x,y)
82.js中的窗口滚动到位置:window.scrollby
83.js中设置时间间隔:setinterval(”expr”,msecdelay)或setinterval(funcref,msecdelay)或settimeout
84.js中的模态显示在ie4+行,在nn中不行:showmodaldialog(”url”[,arguments][,features]);
85.js中的退出之前使用的句柄:function verifyclose(){event.returnvalue=”we really like you and hope you will stay longer.”;}} window.onbeforeunload=verifyclose;
86.当窗体第一次调用时使用的文件句柄:onload()
87.当窗体关闭时调用的文件句柄:onunload()
88.window.location的属性: protocol(http:),hostname(),port(80),host(),pathname(”/a/a.html”),hash(”#giantgizmo”,指跳转到相应的锚记),href(全部的信息)
89.window.location.reload()刷新当前页面.
89-1.parent.location.reload()刷新父亲对象(用于框架)
89-2.opener.location.reload()刷新父窗口对象(用于单开窗口)
89-3.top.location.reload()刷新最顶端对象(用于多开窗口)
90.window.history.back()返回上一页,window.history.forward()返回下一页,window.history.go(返回第几页,也可以使用访问过的url)
91.document.write()不换行的输出,document.writeln()换行输出
92.document.body.nowrap=true;防止链接文字折行.
93.变量名.charat(第几位),取该变量的第几位的字符.
94.”abc”.charcodeat(第几个),返回第几个字符的ascii码值.
95.字符串连接:string.concat(string2),或用+=进行连接
96.变量.indexof(”字符”,起始位置),返回第一个出现的位置(从0开始计算)
97.string.lastindexof(searchstring[,startindex])最后一次出现的位置.
98.string.match(regexpression),判断字符是否匹配.
99.string.replace(regexpression,replacestring)替换现有字符串.
100.string.split(分隔符)返回一个数组存储值.
101.string.substr(start[,length])取从第几位到指定长度的字符串.
102.string.tolowercase()使字符串全部变为小写.
103.string.touppercase()使全部字符变为大写.
104.parseint(string[,radix(代表进制)])强制转换成整型.
105.parsefloat(string[,radix])强制转换成浮点型.
106.isnan(变量):测试是否为数值型.
107.定义常量的关键字:const,定义变量的关键字:var
请教一个简单的Javascript问题
因为你只有一个i变量, 在你这一段代码执行完之后, 结果大概是这样的
首先 i = 5; 这个不用多解释吧, for循环完了之后i变量自增长到了5
然后
lis[0] = function(){ alert( ‘点击了第’ + i + ‘个标签’ ); } // 注意,问题就是这里, lis[0]这里的i是每一次循环的值, 所以这里是0, 而后面函数里面的依然是i, 因为此时函数未执行, 后面4个也一样
.
.
.
lis[4] = function(){ alert( ‘点击了第’ + i + ‘个标签’ ); }
然后当你触发点击事件的时候, 上面的函数才被调用, 此时for循环早已执行完毕, 所以此时的alert出来的i是等于5的, 所以不管你点哪个都是5
解决办法是对for循环内的代码进行闭包, 所谓闭包就是匿名函数的自动调用, 形式就是
for( var i = 0; i lis.length; i++ )
{
(function( i ){ // 闭包开始
lis[i] = function(){ alert( ‘点击了第’ + i + ‘个标签’ ); };
})( i ); // 闭包结束, 将i作为参数传给匿名函数
}
for( var i = 0; i lis.length; i++ )
{
(function(){ // 闭包开始
var j = i;
lis[j] = function(){ alert( ‘点击了第’ + j + ‘个标签’ ); };
})(); // 闭包结束, 或者可以在匿名函数内声明另外的变量来保存此时i的值
}
在地址栏如何直接使用javascript函数?
方法一:
打开一个网页以后,清除地址栏,然后在地址栏键入“javascript:alert(‘hello world’);”。
然后就会弹出一个对话框显示’hello world’, 当然你可以在这里键入更多的代码,来运行代码。
最直接的方法是用来查询该页面上的一些信息,比如查询背景颜色:javascript:alert(document.body.style.backgroundColor);void(0);
当然你可以查询更多,比如cookie:javascript:alert(document.cookie);
利用javascript重定向:javascript:document.location=。
方法二:
另一个用法是通过void来修改form,通常你可以修改form,提交表单,来得到修改后的结果。假设有个表单有个隐藏field price=100, 你可以通过javascript: oid(document.forms[0].price.value= 100); alert(document.forms[0].price.value);来将这个price的值修改成100, 然后再提交表单。
javascript即时函数的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于、javascript即时函数的信息别忘了在本站进行查找喔。