还以为这是Native.js里面的内容,然后去官方文档中翻看了一下Njs的内容,并不是啊,然后去百度。...自执行函数 自执行函数(function(jquery){}(jquery)); * 相当于下面的代码: var fun = function(jquery){}; fun(jquery)...; * 立即执行匿名函数fun(jquery);主要是为了避免jquery与其他类库或变量有冲突。...mui的demo中(function($, doc) {}(mui, document));据说可以让函数在文档加载完毕之后再执行,相当于 $(document).ready(function (){...//函数体 });
匿名函数与自执行函数 匿名函数就是指的没有名字的函数,即定义函数对象时不定义函数体名字,但是必须将匿名函数作为表达式赋予一定操作,比如将其作为变量值或者让其自执行,否则这次定义将无意义,解释器也会抛出异常...即我们用声明式写函数,可以在任何区域声明,不会影响我们调用 */ function s(){ console.log(1); } /** * 定义匿名函数 函数表达式 * 函数表达式中的...自执行函数 自执行即函数定义与创建合用为一体,创建完成即调用 (function() { console.log(1); })(); // 1 包围函数的第一段括号返回一个匿名函数,随后第二个括号将其调用...这种方式可以缩小作用域,ES6之前JS仅有全局作用域与函数作用域,显然将所有变量交予全局作用域是不合适的,而定义函数再调用再销毁函数操作了三步,使用自执行匿名函数可以将上述三步操作定义后即完成。.../** * 自执行的一些方式 * 只要能够将匿名函数作为一个表达式出现,在后边加入()就能够将其自执行 */ // 这种经常用来构建沙箱模式 (function () { console.log
学习闭包的基础知识: 函数声明 function fn(){ //这里是代码 }; fn(); //运行fn函数 与上面等价 var fn = function(){ //这里是代码 } fn(...); //运行 对fn()进行替换一下 (fn)()等价与fn() (function(){ //这里是代码 })() 测试: (function(){ var str= '自运行' alert...(str); //就可以运行了 })() alert(str); //不能访问str变量 这样作的好处尽可能的少用全局变量
一、主动执行函数。...众所周知,函数一般有下面几种表现方式:第一种:函数声明function demo_one(){console.log(“this is demo-one”);}第二种:函数表达式var demo=function...,简单的叫做函数体,现在还不是函数表达式。...console.log(this.name);//输出 maomin}main();这里的main函数称为主动执行函数,什么叫主动执行函数呢?就是立即执行的函数啊。...显然,最初声明的函数体如果没有下面的mian(),就不能执行,这里的main()叫做函数调用,先声明后调用。
onClick中的函数自动被调用问题 来看如下两种html片段 // 每次加载都会执行一次 合同 // 正常执行 this.clickCon}>合同 原因 第一种写法是每次加载时,先调用...clickCon方法,然后将执行结果赋给onclick,每次都会执行 后面一种是将clickCon方法传递给onclick,所以只有触发click才会执行 解决方法 使用匿名函数 // 正常执行 <a
立即执行函数 目录 立即执行函数 作用 参数 返回值 立即执行函数 立即执行函数模式是一种语法,可以让你的函数在定义后立即被执行。...立即执行函数的组成 定义一个函数 将整个函数包裹在一对括号中 将函数声明转换为表达式 在结尾加上一对括号 让函数立即被执行 代码实例 (function () { console.log("...app") })() 作用 页面加载完成后只执行一次的设置函数。...将设置函数中的变量包裹在局部作用域中,不会泄露成全局变量。...注意 通常你不应该给立即执行函数传递太多的参数,因为它很快会成为一个负担——为了理解代码是如何工作的,你不得不经常上下滚动源代码。
格式: 格式一:(function(){})() 格式二:(funtion(){}()) 理解: 立即执行函数会将声明的函数表达式执行。...并且在多人的开发项目上,你在全局或局部作用域中声明了一些变量,可能会被其他人不小心用同名的变量给覆盖掉。由于javascipt的自由性。...没有私有域的概念,这样写可以模仿一个私有作用于,用匿名函数作为一个容器,容器内部可以访问外部变量,而外部变量不能访问内部变量。俗称”匿名包裹器“或者“命名空间”。 ...并且在匿名函数容器中写函数然后通过赋值的方法,可以变向的到达java类的效果。将方法存进变量里,全局调用。...var rxr=r.control={}; var ff=22; rxr.ss=11; rxr.aa=function(){ console.log('执行
大家好,又见面了,我是你们的朋友全栈君。 js匿名函数和立即执行函数 1. 匿名函数 a)写法 b) 特点 2. 立即执行函数 a) 写法 b) 特点 c) 示例 1....var hello=function(){ console.log("hello"); }; hello();//hello b) 特点 匿名函数可以直接访问到外层署名函数(Foo)中的变量...(使用关键字var定义的),但不能访问外层署名函数的属性(使用关键字this定义的) 匿名函数既可以直接访问外层匿名函数中的变量,也可以直接访问外层匿名函数中的属性 外层函数类型: 署名函数 匿名函数...立即执行函数 该类函数没有声明,直接执行,执行完立即释放。一般做初始化比较合适。...,如function (){}(),这样不行,因为function (){}是声明不是表达式,如果是var fn=function (){}();就可以 但执行后,函数名或者变量就不代表函数了,被执行符号执行的表达式其函数名字将被忽略
在JavaScript中,会遇到自执行匿名函数:(function () {/*code*/} ) ()。 这个结构大家并不陌生,但若要说:为什么要括弧起来?它的应用场景有哪些?...但因遇到了自执行函数,当时的i值已经被 lockedIndex锁住了。也可以理解为 自执行函数属于for循环一部分,每次遍历i,自执行函数也会立即执行。...注意:自执行函数在 setTimeout 和在 setTimeout 里在第2、3中情况有区别(原因不明,后续再补)。...以下是截取该参考博文的例子: // 自执行函数。自己调用自己(递归) function foo() { foo(); } // 自执行的匿名函数。...个人愚见:上面例子中把 自执行 解释成 “自己调用自己”,当然和 立即执行 相差很大了。但如果把 自执行 解释成 “自动执行”,就和 立即执行 异曲同工了。
什么是函数? * 具有特定功能的n条语句的封装体 * 只有函数是可执行的, 其它类型的数据是不可执行的 * 函数也是对象 2. 为什么要用函数? * 提高代码复用 * 便于阅读和交流 3....如何定义函数? * 函数声明 * 表达式 4. 如何调用(执行)函数?...根据年龄输出对应的信息 2. 如果小于18, 输出: 未成年, 再等等! 3. 如果大于60, 输出: 算了吧! 4. 其它, 输出: 刚好!...什么函数才是回调函数? * 你定义的 * 你没有直接调用 * 但最终它执行了(在特定条件或时刻) 2. 常见的回调函数?...* DOM事件函数 * 定时器函数 * ajax回调函数(后面学) * 生命周期回调函数(后面学) --> //1.
js函数执行过程的探究 说明 函数的执行过程分为两个阶段,第一阶段是创建执行上下文环境的阶段,第二阶段是代码执行的阶段。...1、创建执行上下文环境 创建变量对象,建立作用域链,确定当前上下文环境中寻找变量的规则,确定this对象的指向 2、代码执行阶段 执行函数体内的代码,在此阶段完成变量值、函数引用和其他代码。...在进入执行阶段之前,变量对象的属性还不能访问。但是,进入执行阶段后,变量对象的制作成为活动对象,可以访问其属性,开始执行阶段的操作。变量对象和活动对象的唯一区别就是处于执行上下文的不同生命周期。...以上就是js函数执行过程的探究,希望对大家有所帮助。更多js学习指路:js教程 推荐操作环境:windows7系统、jquery3.2.1版本,DELL G3电脑。
ES6出现了一个可以替代自执行函数的东西。 拿实例说话 就算没仔细看过jquery源码,想比你也见过开头的这种代码: 这是一种典型的自执行函数,也就是立即执行函数。...先来比较一下下面两段代码: 1.1 自执行函数 var v = "hello"; (function(){ console.log(v); var v = "world"; })(); 输出:...如果说没有使用自执行函数,结果是这样的: 1 var deletedIds = []; 你在代码中已经定义过deletedIds,jquery中再定义一个,是不是把你的覆盖掉? 2....加一个方法 那聪明的你要说了,可以写在一个函数中啊。是的,没错。...不能,得先执行jquery()方法才能调用(selector)。 3. 加一个自执行函数 什么是自执行函数,只要加载该文件,它就会自执行函数。
大家好,又见面了,我是你们的朋友全栈君。 定义:匿名函数顾名思义指的是没有名字的函数,在实际开发中使用的频率非常高!也是学好JS的重点。 匿名函数:没有实际名字的函数。...解决方法只需要给匿名函数包裹一个括号即可: //匿名函数在其它应用场景括号可以省略 (function (){ //由于没有执行该匿名函数,所以不会执行匿名函数体内的语句。...console.log("张培跃"); }) 如果需要执行匿名函数,在匿名函数后面加上一个括号即可立即执行!...JavaScript中是没有块级作用域的,例如: if(1==1){//条件成立,执行if代码块语句。...执行完匿名函数,存储在内存中相对应的变量会被销毁,从而节省内存。再者,在大型多人开发的项目中,使用块级作用域,会大大降低命名冲突的问题,从而避免产生灾难性的后果。
今天我们要说的是结合ES6新特性谈一下js里面的一个很好用的方法-find() 现在的前端和过去的不一样,过去的前端只要会画页面就行了,但是现在仅仅会画页面已经远远不够了,现在前端还需要会处理数据,而且还要会将数据分析分类处理...下面我们讲怎么用前端处理这块的逻辑 首先我们拿到了所有的数据这里我直接放到一个测试用的js里面存放, 要实现之前说的效果,就需要使用我们今天的主角find()方法。 find()是用来做什么的呢?...find()方法返回数组中符合测试函数条件的第一个元素。否则返回undefined 在本文章需要注意的几个点: ①、第一个元素 ②、测试函数 那么如何使用呢?.../find_testcodes.js" type="text/javascript" charset="utf-8">
JS中的高阶函数 高阶函数是指以函数作为参数的函数,并且可以将函数作为结果返回的函数。 1....高阶函数 接受一个或多个函数作为输入 输出一个函数 至少满足以上一个条件的函数 在js的内置对象中同样存在着一些高阶函数,像数组的map,filter,reduce方法等,它们接受一个函数作为参数,并应用这个函数到列表的每一个元素...1.1 map map方法接收一个函数作为参数 ,遍历数组,并且返回一个新的数组,新的数组里的每个元素都执行map传入的函数。...如果需要实现后置通知,只需要将6,7行换以下就可以了 实现的原理 在调用公共函数时,传入我们需要执行提前执行的函数,在内部函数执行前先调用该函数 3....Function.prototype.bind 函数就是一个偏函数的典型代表,它接受的第二个参数开始,为预先添加到绑定函数的参数列表中的参数 4.
分享一个JS封装的运动函数,里面分为弹性运动和缓冲运动两个方法,通过调用startMove()函数来实现动画效果。...obj, attr_in, value_in) }; } } var MOVE_TYPE = { BUFFER: 1, FLEX: 2 }; // 调用运动的函数...,根据不同类型调用不同的方法 function startMove(obj, oTarget, iType, fnCallBack, fnDuring) { var fnMove = null;
我们经常需要统计一个函数的执行耗时来判断函数的性能或者用于其他用途。JS 函数统计耗时主要有如下几种办法。...console.time()和console.timeEnd()方法均使用一个参数表示计数器的名称,参数值可以是任何字符串,但是这两个方法所使用的参数字符串必须相同,才能正确地统计出开始时间与结束时间之间所经过的毫秒数...performance 是一个全局对象,提供了获取性能相关的信息的方法。performance.now()返回进程启动至当前逝去的毫秒数,其中 0 表示当前进程的开始。...function var end = performance.now(); console.log('cost is', `${end - start}ms`) ---- 参考文献 [1] 博客园.在JS...中统计函数执行次数与执行时间 [2] Node.js.Performance [3] Node.js.Console
async函数返回的是一个promise对象,如果在函数中 return 一个直接量,async 会把这个直接量通过 Promise.resolve() 封装成 Promise 对象。...await后面的函数会先执行一遍,然后就会跳出整个async函数来执行后面js栈(后面会详述)的代码。...,等本轮事件循环执行结束后,又会跳回到async函数中(test函数),等待之前await 后面表达式的返回值,因为testSometing 不是async函数,所以返回的是一个字符串“testSometing...这个就是在async/await 函数之后js的执行顺序,我们再看一个列子把testSometing函数前面加上async async function testSometing() { console.log...async/await进行异步操作时js的执行顺序。
JavaScript函数: 也称为方法,用来存储一块代码,需要的时候调用。 函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。...JavaScript中的函数定义: //定义函数jiSun function jiSuan(){ alert("这是函数jiSuan"); } //调用函数...function是定义函数,并不会执行,调用函数时才会寻找该函数名的定义内容。 JavaScript中函数的定义和调用先后顺序可以先写调用在写定义。...补充:强类型语言中有默认值的函数,js不支持有默认值的函数 function jiSuan(a,b=2){ alert(a+b); } //调用函数 jiSuan...如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。
领取专属 10元无门槛券
手把手带您无忧上云