1.python 中__name__ = '__main__' 的作用 如果我们是直接执行某个.py文件的时候,该文件中那么”__name__ == '__main__'“是True,但是我们如果从另外一个...__contains__(y) 等价于 y in x, 在list,str, dict,set等容器中有这个函数 __base__, __bases__, __mro__, 关于类继承和函数查找路径的...__sizeof__(), x在内存中的字节数, x为class得话, 就应该是x.__basicsize__ x....__setattr__ 取代一般的赋值操作,如果有此函数会调用此函数, 如想调用正常赋值途径用 object...._name__ = '__main__' 的作用:https://www.cnblogs.com/alan-babyblog/p/5147770.html 2.python中那些双下划线开头得函数和变量
什么是函数? * 具有特定功能的n条语句的封装体 * 只有函数是可执行的, 其它类型的数据是不可执行的 * 函数也是对象 2. 为什么要用函数? * 提高代码复用 * 便于阅读和交流 3....如何定义函数? * 函数声明 * 表达式 4. 如何调用(执行)函数?...根据年龄输出对应的信息 2. 如果小于18, 输出: 未成年, 再等等! 3. 如果大于60, 输出: 算了吧! 4. 其它, 输出: 刚好!...什么函数才是回调函数? * 你定义的 * 你没有直接调用 * 但最终它执行了(在特定条件或时刻) 2. 常见的回调函数?...* DOM事件函数 * 定时器函数 * ajax回调函数(后面学) * 生命周期回调函数(后面学) --> //1.
今天我们要说的是结合ES6新特性谈一下js里面的一个很好用的方法-find() 现在的前端和过去的不一样,过去的前端只要会画页面就行了,但是现在仅仅会画页面已经远远不够了,现在前端还需要会处理数据,而且还要会将数据分析分类处理...下面我们讲怎么用前端处理这块的逻辑 首先我们拿到了所有的数据这里我直接放到一个测试用的js里面存放, 要实现之前说的效果,就需要使用我们今天的主角find()方法。 find()是用来做什么的呢?...find()方法返回数组中符合测试函数条件的第一个元素。否则返回undefined 在本文章需要注意的几个点: ①、第一个元素 ②、测试函数 那么如何使用呢?.../find_testcodes.js" type="text/javascript" charset="utf-8">
大家好,又见面了,我是你们的朋友全栈君。 定义:匿名函数顾名思义指的是没有名字的函数,在实际开发中使用的频率非常高!也是学好JS的重点。 匿名函数:没有实际名字的函数。...首先我们声明一个普通函数: //声明一个普通函数,函数的名字叫fn function fn(){ console.log(“张培跃”); } 然后将函数的名字去掉即是匿名函数: //匿名函数...JavaScript中是没有块级作用域的,例如: if(1==1){//条件成立,执行if代码块语句。...在这里简单介绍一下:闭包是可以访问在函数作用域内定义的变量的函数。若要创建一个闭包,往往都需要用到匿名函数。 2、模拟块级作用域,减少全局变量。...执行完匿名函数,存储在内存中相对应的变量会被销毁,从而节省内存。再者,在大型多人开发的项目中,使用块级作用域,会大大降低命名冲突的问题,从而避免产生灾难性的后果。
分享一个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中的高阶函数 高阶函数是指以函数作为参数的函数,并且可以将函数作为结果返回的函数。 1....高阶函数 接受一个或多个函数作为输入 输出一个函数 至少满足以上一个条件的函数 在js的内置对象中同样存在着一些高阶函数,像数组的map,filter,reduce方法等,它们接受一个函数作为参数,并应用这个函数到列表的每一个元素...,这里就不一一说明了,从上面的三个方法中,已经能很直观的感受到了函数接收函数作为参数,再返回值的过程,逼格很高也很好用 2....把一些与业务无关的功能抽离出来,通过"动态植入"的方法,掺入到业务逻辑模块中。...Function.prototype.bind 函数就是一个偏函数的典型代表,它接受的第二个参数开始,为预先添加到绑定函数的参数列表中的参数 4.
大写加下划线的变量: 标明是 不会发生改变的全局变量函数:1. 前带_的变量: 标明是一个私有函数, 只用于标明,2....前带两个_ ,后带两个_ 的函数: 标明是特殊函数 if __name__ == '__main__':(Python 用下划线作为变量前缀和后缀指定特殊变量。..._xxx 不能用'from module import *'导入 __xxx__ 系统定义名字 __xxx 类中的私有变量名 核心风格:避免用下划线作为变量名的开始。...私有变量 : 小写和一个前导下划线_private_valuePython 中不存在私有变量一说,若是遇到需要保护的变量,使用小写和一个前导下划线。...同时也应该注意一般函数不要使用两个前导下划线(当遇到两个前导下划线时,Python 的名称改编特性将发挥作用)。特殊函数后面会提及。
JavaScript中的函数定义: //定义函数jiSun function jiSuan(){ alert("这是函数jiSuan"); } //调用函数...function是定义函数,并不会执行,调用函数时才会寻找该函数名的定义内容。 JavaScript中函数的定义和调用先后顺序可以先写调用在写定义。...补充:强类型语言中有默认值的函数,js不支持有默认值的函数 function jiSuan(a,b=2){ alert(a+b); } //调用函数 jiSuan...(3); JavaScript中的常用函数: document.write(""); 输出语句 Math.random();获取0-1之间的随机数 document.write(Math.random...如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。
大家好,又见面了,我是你们的朋友全栈君。 匿名函数里的对象,跟定义匿名函数页面的上下文有关,而与调用匿名函数的页面无关。 很拗口。...showWorkSpace(callback, h) { var height = 500; callback("map_workspace",height); } //在该“容器”页面中的某个...frame frameMap' style='width:100%;height:" + h + ";' src='" + url + "'>"); }); 匿名函数在...iframe里定义,而在“容器”页面执行,而$(“#map_workspace”)对象很明显在“容器”页面上,但偏偏,没有获得我们预期的结果。...showWorkSpace(callback, h) { var height = 500; callback($("#map_workspace"),height); } //在该“容器”页面中的某个
html lang="en"> Document //工厂函数是专门创建对象的函数
map函数 首先让我们回顾一下,map函数的第一个参数callback: var new_array = arr.map(function callback(currentValue[, index[,...parseInt函数 parseInt 基数是一个介于2和36之间的整数。...parseInt(string, radix) //接收两个参数,第一个表示被处理的值(字符串),第二个表示为解析时的基数。 模拟情况 了解这两个函数后,我们可以模拟一下运行情况。...这个时候返回1 parseInt('2', 1) //基数为1(1进制)表示的数中,最大值小于2,所以无法解析,返回NaN parseInt('3', 2) //基数为2(2进制)表示的数中,最大值小于...3,所以无法解析,返回NaN map函数返回的是一个数组,所以最后结果为[1, NaN, NaN]
首先,什么是匿名函数? - 匿名函数主要利用函数内的变量作用域,避免产生全局变量,影响整体页面环境,增加代码的兼容性。(如下图) ? 那么 他的作用是什么?...我们首先假设一个场景,一个网站使用了jQuery框架进行了许多的DOM操作,然而,在“有心人”的操作之下,能够将整个jQuery的'$'函数变成其他的功能,例如: 在控制台中输入: $=null...如何避免 将页面中使用的各类函数都封在以下函数中: (function ($) { })($); 将jQuery特有的'$'符号作为参数传入匿名函数中以保护页面中的内容...,当然,除了jQuery也有其他的框架也可能需要有这样的匿名函数来保护页面。...---- 个人的看法:这个匿名函数也有些类似于ES6中的let方法,所声明的内容能够有效避免全局变量的产生,所以即使在控制台中,也不能够随意改变该页面的内容,我想 let方法的出现可能就是为了补充前面的不足吧
_接收,除此以外,单下划线在python中会默认与上一次运算过程中的非None结果保存下来(注意赋值语句相当于None,与C语言区分开),有点类似于计算器的ans功能: >>> 2+2 4 >>> a=..._解决命名冲突问题 编程过程中如果声明的变量是python的保留字的话,这个时候如果想要使用该保留字作为变量名称,则可以加一个_,如创建一个变量class_。..._var用于保护变量 保护变量是指那些程序员约定俗成的,作为调用细节不需要操作者关心的一些变量,这些变量python的解释器不做访问限制,但是因为这些变量的缺失并不会对我们调用函数带来什么困难,如果直接导入还存在干扰我们的命名空间的可能...all列表(__all__=[_var])中,接着我们就可以使用from XXX import *导入在列表中的保护属性。...当然这种改写机制也并非真正含义上的私有,python中不存在绝对私有的变量,只是通过这种改写方式告诉我们,这段程序的主人不希望我们变动私有属性的值。
可以看到, 给a赋值的5, 并没有赋值到全局变量a上 解决 先看看MDN里的说明 ? 从ES6开始 在严格模式下,块里的函数作用域为这个块。ES6之前不建议块级函数在严格模式下使用....在ES6非严格模式下, 块中函数声明会出现提升, 所以最好使用函数表达式来定义函数 ---- 走走流程看看到底发生了啥 我们可以先把, function a () {}注释掉, 可以看到报错了, Uncaught...ReferenceError: a is not defined, 所以if里的函数声明确实存在变量提升 ?...然后, 我们可以打点调试一下 在if 中的a=1语句之前, 我们可以看到函数声明已经提升了, 此时if作用域里a为函数 ? 而全局的a还是undefined ?...随后运行a=5, 则只是在块级作用域里的赋值, 不会对全局作用域的a值进行修改 ---- 当然, 如果使用函数表达式来声明函数的话, 可以避免 var a if (true) { console.log
在 HTML 也好,Word 也好,基本都有下划线和删除线(中划线)。 Fabric.js 作为一个老牌 canvas 库,当然也提供中划线和下划线的配置啦,除此之外还提供了上划线的配置。...\n\n\n 本文要讲解的就是这3种装饰线在 fabric.js 中的使用方法。除了初始化配置外,还支持项目运行时,让用户动态配置。本文案例使用了 IText ,该组件支持编辑功能。...初始化时设置 这是上划线、中划线和下划线的文档: - 上划线 overline - 中划线 linethrough - 下划线 underline <canvas id="c" width="300"...换行的方法是文本内容里使用\n做换行。 动态设置 除了在初始化时可以设置装饰线外,Fabric.js 也提供了在运行时用户手动设置。不过代码会稍微复杂一点。...其实动态设置上划线、中划线和下划线的操作都是一样的,唯一要变的就是属性名。 我以中划线为例,之后上划线和下划线只需改个属性名。
Python中下划线---完全解读 Python 用下划线作为变量前缀和后缀指定特殊变量_xxx 不能用from module import *导入__xxx__系统定义名字__xxx类中的私有变量名核心风格...:避免用下划线作为变量名的开始。...因为下划线对解释器有特殊的意义,而且是内建标识符所使用的符号,我们建议程序员避免用下划线作为变量名的开始。一般来讲,变量名_xxx被看作是“私有 的”,在模块或类外不可以使用。...以单下划线开头_foo的代表不能直接访问的类属性,需通过类提供的接口进行访问,不能用from xxx import *而导入;以双下划线开头的__foo代表类的私有成员;以双下划线开头和结尾的__foo...__代表python里特殊方法专用的标识,如__init__()代表类的构造函数。
Python中没有访问控制的关键字,例如private、protected等等。但是,在Python编码中,有一些约定来进行访问控制。...1、单下划线"_" 在Python中,通过单下划线"“来实现模块级别的私有化,变量除外。...一般约定以单下划线”"开头的函数为模块私有的,也就是说"from moduleName import * “将不会引入以单下划线”"开头的函数。..._call_for() TypeError: 'NoneType' object is not callable 2、双下划线"__" 对于Python中的类属性,可以通过双下划线"__“来实现一定程度的私有化...,由于没有定义 _ init 函数,将调用父类的 _ init_ _,但是由于双下划线的"混淆"效果,"self.
所以通过这里就可以理解函数式编程其实就是强调在编程过程中把更多的关注点放在如何去构建关系,通过构建一条高效的建流水线,一次解决所有问题,而不是把精力分散在不同的加工厂中来回奔波传递数据。...由于Js中对象传递的是引用地址,哪怕我们用const关键词声明对象,它依旧是可以变的。保证函数没有副作用,一来能保证数据的不可变性,二来能避免很多因为共享状态带来的问题。...,在我的理解中柯里化实际就是实现了一个状态机,当达到指定参数时就从继续接收参数的状态转换到执行函数的状态。...,但是不够方便,现在实现一个Thunk函数的自动流程管理,其自动帮我们进行回调函数的处理,只需要在Thunk函数中传递一些函数执行所需要的参数比如例子中的index,然后就可以编写Generator函数的函数体...,通过左边的变量接收Thunk函数中funct执行的参数,在使用Thunk函数进行自动流程管理时,必须保证yield后是一个Thunk函数。
好吧,一直在秋招中,都没怎么写博客了。。。今天赶紧来补一补才行。。。我发现,在面试中,讲到函数节流好像可以加分,尽管这并不是特别高深的技术,下面就聊聊吧!...^_^ 备注:以下内容部分来自《JavaScript高级程序设计》 函数节流的目的 从字面上就可以理解,函数节流就是用来节流函数从而一定程度上优化性能的。...但是我们的目的主要是每输入一些内容搜索一次而已。为了解决这些问题,就可以使用定时器对函数进行节流。 函数节流的原理 某些代码不可以在没有间断的情况连续重复执行。...例子场景:实现常见的搜索功能 ①没有使用函数节流的情况下,为input绑定keyup事件处理函数,在控制台输出我输入的内容。...实际上,我们更希望的是,当达到某个时间值时,一定要执行一次这个搜索函数。所以,就有了函数节流的改进模式。
领取专属 10元无门槛券
手把手带您无忧上云