函数进阶

1. 函数防抖

在频率触发的情况下 只有等待一定的时间才会触发 执行一次代码

特点

  • 执行之前先清除之前的即将执行操作 保证只有最后一次生效

  • 优化高频执行JS代码操作

  • 提高性能

防抖代码实现

  // 使用setTimeout实现函数防抖
var t = null;
document.onmousemove = function (){
// 每次移动之前清除先前计时器
clearTimeout(t);
t = setTimeout(() => {
// 等待300毫秒后执行打印语句
console.log('鼠标移动停止300毫秒打印');
}, 300);
}

防抖应用场景

一些高频率事件 在被连续多次触发时 只需生效一次

  1. 搜索输入框 用户可能输入很快 在输入停止一段时间后再将请求发送

  2. 用户名 手机号 邮箱注册时验证是否符合规范

  3. 窗口大小时间resize 只需在窗口调整完成后再主席那个resize里代码 防止重复渲染 浪费性能


2. 函数节流

在频率触发的情况下 每间隔一段时间才触发一次

特点

  • 前一次存在触发执行未结束 后一次触发执行不会开始

  • 优化高频执行JS代码操作

  • 提高性能

节流代码实现

  // 利用 状态 概念
var t = null;
document.onmousemove = function (){
// 当计时器处于开启状态 不再重新开启新计时器
if(t) return;
t = setTimeout(() => {
console.log("函数节流每300毫秒触发一次");
t = null;
}, 300);
}

节流应用场景

一些高频率事件 间隔一段时间运行一次 被连续多次触发如果处于间隔时间内无效

  1. 鼠标移动事件 如元素拖拽 获取鼠标坐标

  2. 页面中的滚动事件

  3. 频繁点击提交按钮

  4. 游戏中一些设计 如: 枪射速 每1000毫秒触发一次 每500毫秒触发一次


3. 闭包函数

概念

  • 有权访问另一个函数中的变量 并让函数不会因为执行完毕而被销毁

原理

  • 让函数定义和表达式通过另一个函数return出来 这样在里面的函数就可以访问另一个函数内的变量 当外部函数被调用时就会返回一个内部函数

作用

  • 在函数内部可以访问到外部变量
  • 避免全局变量命名空间的污染
  • 延长变量生命周期
  • 函数不会因为执行完毕而被销毁

闭包函数的创建

  // 立即执行函数使fn得到return返回值
const fn = (function(){
let a = 10;
return function(){
return a;
}
})()
// fn返回值为函数 加上()调用函数得到此函数return值
console.log(fn()); // 10

闭包函数的应用

  const divs = document.querySelectorAll("div");

  // 添加了错误索引
for(var i = 0; i < divs.length; i++){
divs[i].onclick = function(){
// 因为异步原因 执行点击事件时 i已经为最大值
console.log(i);
}
} // 添加了正确索引
// 方法一
for(var i= 0; i < divs.length; i++){
;(function(i){
divs[i].onclick = function(){
console.log(i);
}
})(i);
} // 方法二
for(var i = 0; i < divs.length; i++){
divs[i].onclick = (function(i){
return function(){
console.log(i);
}
})(i);
} // 方法三
for(let i=0;i<divs.length;i++){
divs[i].onclick = function(){
console.log(i);
}
}

沙箱模式

  function outer() {
let a = 10;
let str = 'hello world'; // 返回一个对象
return {
// 对每个私有变量都准备两个函数:get用来获取,set用来修改
getA () { return a },
setA (val) { a = val },
getStr (val) { return a },
setStr: function (val) { a = val }
}
// 使用数据劫持中getter和setter优化
// return {
// get A() {return a}
// set A(val) {a = val}
// get Str() {return str}
// set Str(val) {str = val}
// }
}

4. 函数柯里化(Curring)

将一次传入多个参数的函数 转换为多次执行 一次执行传入一个参数的函数

例如 fn(1, 2, 3) 转换为 fn(1)(2)(3)

利用闭包延长变量生命周期把每次的传递参数保存下来 也可以保存每层function中程序

  function fn1(a, b){
return a + b
} function fn2(a) {
return function (b) {
return a + b
}
}
fn1(1, 2) // 3
fn2(1)(2) // 3
// 解析
// fn2(1) 返回function(b) {return a + b} 并且这个返回的函数能访问到第一次传入的值1 并且 值1生命周期没有结束 fn2(1)(2)返回a + b = 3

Function-advanced的更多相关文章

  1. C#编程经验-function advanced params

    function advanced params:outrefparamsnot useful,to use them is a burden,so i dont use themdefects:ou ...

  2. 【cocos2d-js公文】十八、Cocos2d-JS v3.0物业风格API

    1. 新的API风格 我们直接来看看你能够怎样使用Cocos2d-JS v3.0: 曾经的API 新的API node.setPosition(x, y); node.x = x; node.y = ...

  3. 通过百度echarts实现数据图表展示功能

    现在我们在工作中,在开发中都会或多或少的用到图表统计数据显示给用户.通过图表可以很直观的,直接的将数据呈现出来.这里我就介绍说一下利用百度开源的echarts图表技术实现的具体功能. 1.对于不太理解 ...

  4. machine learning(11) -- classification: advanced optimization 去求cost function最小值的方法

    其它的比gradient descent快, 在某些场合得到广泛应用的求cost function的最小值的方法 when have a large machine learning problem, ...

  5. [Javascript] Advanced Function Scope

    Something like 'for' or 'while', 'if', they don't create a new scope: ,,]; ; i < ary.length; i++) ...

  6. sleep function error ("Advanced Programming in the UNIX Environment" Third Edition No.374)

    测试证明代码: #include <unistd.h> #include <fcntl.h> #include <time.h> #include "ap ...

  7. CAST function should support INT synonym for SIGNED. i.e. CAST(y AS INT)

      Login / Register Developer Zone Bugs Home Report a bug Statistics Advanced search Saved searches T ...

  8. Emiller's Advanced Topics In Nginx Module Development

    Emiller的Nginx模块开发指南 By Evan Miller DRAFT: August 13, 2009 (changes) 翻译:Kongch @2010年1月5日 0:04am -- 2 ...

  9. Advanced Awk for Sysadmins

    转:http://www.linuxforu.com/2011/06/advanced-awk-for-sysadmins/ By Vishal Bhatia on June 1, 2011 in H ...

  10. Advanced Configuration Tricks

    Advanced Configuration Tricks Configuration of zend-mvc applications happens in several steps: Initi ...

随机推荐

  1. node express框架搭建

    前面了解了一些node.js的服务建立及事件绑定和触发,要想一步一步自己来写所有响应,还是比较麻烦,看了express,很多东西都由框架自动完成,开发人员仅需关注自己想要实现的功能即可,真正实现了让开 ...

  2. 树莓派3B+ wifi设置

    环境: 硬件:树莓派 3b+ 固件:2018-04-18-raspbian-stretch.img 一.树莓派配置 1.1.wifi配置方法一(已测试,ok) 参考: https://www.cnbl ...

  3. 用C#语言实现记事本

    一.实验内容: 二.记事本所需功能: (1)记事本程序具有文件的新建.打开.保存功能: (2)文字的复制.粘贴.删除功能:字体类型.格式的设置功能: (3)查看日期时间等功能,并且用户可三根据需要显示 ...

  4. 【随笔】记录Centos7 firewall-cmd防火墙的文档与命令记录

    注意:firewall-cmd命令后面的参数前面是两个短-,这里显示的不是很清晰 查看firewall-cmd运行状态 # firewall-cmd --state 开放8080端口 # firewa ...

  5. 将 Sql Server 表信息 C# 对象化 小工具_ 张光荣 的 正能量

    注: a.此程序所得到的结果是根据本人个人习惯生成,所以,肯定不完全适合所有人使用,重在想法...然后个人根据个人需求作出更进...b.程序中可能会出现数据库连接的错误提示[原因概是在sql 连接过程 ...

  6. 微信小程序-顶部下拉菜单实现

    最近写的小程序里面需要实现顶部下拉菜单的效果,做一个过滤操作,但是没有找到相关组件,所以动手写了一个. 先看一下这拙劣的效果叭~ 下面就直接看具体实现了嗷! index.wxml <view c ...

  7. K8S 性能优化 - 大型集群 CIDR 配置

    前言 K8S 性能优化系列文章,本文为第三篇:Kubernetes 大型集群 CIDR 配置最佳实践. 系列文章: <K8S 性能优化 - OS sysctl 调优> <K8S 性能 ...

  8. java代码审计-SpEL表达式注入

    0x01 前言 Spring Expression Language(简称 SpEL)是一种功能强大的表达式语言.用于在运行时查询和操作对象图:语法上类似于Unified EL,但提供了更多的特性,特 ...

  9. GO语言学习笔记-并发篇 Study for Go ! Chapter seven - Concurrency

    持续更新 Go 语言学习进度中 ...... GO语言学习笔记-类型篇 Study for Go! Chapter one - Type - slowlydance2me - 博客园 (cnblogs ...

  10. 前端程序员需要了解的MySQL

    数据库的基本概念 数据库(database)是用来组织.存储和管理数据的仓库.对数据库中的数据可以进行增删改查操作.市面上常见的数据库有: MySQL(使用最广泛.流行度最高的开源免费数据库 Comm ...