- 博客(21)
- 收藏
- 关注
原创 函数式编程(四):函数组合、函子
函数组合 纯函数和柯里化很容易写出洋葱代码 h(g(f(x))),就是一个函数镶嵌另一个函数,多重组合,最终实现我们想要的功能,就像下面这个洋葱一样: 函数组合,就是利用多个函数,把细粒度的函数重新组合生成一个新的函数,从而实现我们想要的逻辑。 比如:获取数组的最后一个元素再转换成大写字母, .toUpper(.first(_.reverse(array))) 管道 下面这张图表示程序中使用函数处理数据的过程,给 fn 函数输入参数 a,返回结果 b。可以想想 a 数据通过一个管道得到了 b 数据: 当
2021-01-04 11:33:43
380
原创 函数式编程(三):纯函数、柯里化
纯函数 什么是纯函数呢?就是很纯的,没有副作用的函数… … 什么是副作用呢,就是那个,吃药的时候,说明书上写明可能产生副作用的那些不正常的作用,这个就是副作用… 好多的废话,看代码吧 简单的纯函数: // 一个简单的纯函数 function add(a, b) { return a + b } // 调用 let sum = add(1, 2) 上面的函数,无论怎么调用,都不会对其他地方产生影响,且对于相同的输入,永远都有相同的输出。 这个就是纯函数。 那么不纯的函数是什么样呢,大概有以下几种:
2021-01-04 10:05:26
246
原创 函数式编程(二):闭包
闭包这词估计已经听烂了,这里随便再复习下它的概念。 闭包 (Closure):函数和其周围的状态(词法环境)的引用捆绑在一起形成闭包。 特点1:可以在另一个作用域中调用一个函数的内部函数并访问到该函数的作用域中的成员。 上文提到的,函数作为返回值和那个支付的例子,就是闭包: function makeFn() { let msg = 'Hello function' return function () { console.log(msg) } } const fn
2021-01-03 15:27:53
424
原创 函数式编程(一):前言、高阶函数
前言 什么是函数式编程呢?ennn…,其实就是一种编程思想,和面向对象编程、面向过程编程是一样的,这玩意一开头说一大堆也不好,先来说说为毛要学函数式编程。 因为将来要学习 React 和 vue 以及剖析其源码,避免不了和函数式编程思想接触。 那函数式编程到底有什么好处呢,主要有如下几点: 不容易产生bug,方便测试和并行处理; 可以抛弃this,避免被this指向弄晕; 打包过程中可以更好的利用 tree shaking 过滤无用代码; 有很多库可以帮助我们进行函数式开发,比如经典的lodash。 来
2021-01-03 11:34:06
354
原创 JavaScript异步编程(五):async、宏任务、微任务
Promise 虽然主要是用来处理异步任务的,但我们深入理解 Promise 并不是纯为了来处理异步任务,因为在 ES7 里的 async 和 wait 能更简单的处理异步任务: // 一个异步任务,在time毫秒后返回一个状态为reject的Promise对象 function ajax(time) { return new Promise((resolve, reject) => { setTimeout(() => { resolve(`完成
2021-01-02 20:35:41
382
原创 JavaScript异步编程(四):并行执行、超时处理
并行执行 或许,可能有遇到过这样的需求: 一个接口的参数是由其他三个接口的返回值组合而成,因此这个接口必须要保证在另外三个接口完成之后才能被调用; 在echarts的图表中,一个图表中可以有好几组数据,每组数据都由一个接口返回,根据echarts使用规则,必须得这几个接口都请求完成之后才渲染图,比如下面这个,有四组数据在同一个echarts表里: 以上两种情况,都是需要在某几个接口请求完毕之后再执行另一个接口。 这个涉及到并行执行的概念,Promise.all() 刚好可以解决这个问题。 上代码: //
2021-01-02 18:47:19
1202
原创 JavaScript异步编程(三):Promise异常处理
异常处理 接上文,Promise中的方法没法保证不出错误,一旦报错,我们必须捕获错误来观察是哪里出了错。 我们故意不传参,制造一个错误来看看: function ajax(param) { return new Promise((resolve, reject) => { setTimeout(() => { if (param) { resolve(param) } else {
2021-01-02 16:12:34
496
原创 JavaScript异步编程(二):Promise基础回顾
Promise相关概念和用法简要回顾: Promise语义理解为承诺,承诺一件事情,这件事情,要么成功,要么失败。放在ajax的处理上,就是ajax请求成功了, 最基本的示例: let promise = new Promise((resolve, reject) => { let flag = true if (flag) { resolve('成功了') } else { reject('失败了') } }) promise.the
2021-01-02 13:22:49
102
原创 JavaScript异步编程(一):同异步执行原理过程
JavaScript(以下简称js)是单线程语言,也就是说在js代码执行环境中,执行代码的线程只有一个,因为设计初衷就是为了操作DOM元素,假设js是多线程语言,那么如果两个线程任务同时操作一个DOM元素,一个修改一个删除,浏览器将不知道以哪个为准。 既然js是单线程语言,所以有多个任务时(先不考虑异步),只能排队一个个按顺序执行。 优点:安全简单;缺点:一个任务耗时阻塞,后面的任务都会只能在等待,无法执行。 为解决异步请求、文件加载等耗时长的任务阻塞后边任务的问题,js执行模式分为同步模式和异步模式。 同
2021-01-01 21:31:15
351
原创 history详解
history 对象包含用户在浏览器中访问过的页面的URL,自带的属性和方法如下: history.length 历史页面的URL数量,最小为1,最大为,即只能存50个历史页面记录。 history.back()、history.forward()、history.go() 分别表示跳转至上一个页面、下一个页面、指定的上下某个页面,history.go(-1) 等同于 history.back(),history.go(1) 等同于 history.forward(),history.go(0) 等同于当前
2020-11-15 13:40:33
2499
原创 路由(Router)原理极简说明
在各种框架中,路由的实现主要有两种方式: 用 hashchange 事件监听 url 来实现; 用 history.pushState() + popstate 来实现。 先看第一种,用 hashchange 实现路由相当简单: // html <a href="#/">首页</a> <a href="#/blog">博客</a> <a href="#/college">学院</a> 当点击 a 标签,hash 值发生变化,触发事
2020-11-14 19:46:48
892
原创 用人话说清bind
bind 常见应用情形主要有两种: 改变 this 指向; 参数固化(又叫偏函数,可理解为函数柯里化的简单应用)。 第一种情形很简单,demo如下: const cat = { name: 'xiaoJu', say: function () { console.log(this.name) } } cat.say(); // xiaoJu const otherCat = { name: 'daHuang' }; cat.say.bind(oth
2020-11-13 23:54:28
133
原创 v-for 和 v-if 同时使用的问题
假设有如下数组,需要将数组中的num渲染至页面中,同时遵循条件:对应的show值为true才渲染,为false就不渲染。 numArr: [ { num: 1, show: true }, { num: 2, show: false }, { num: 3, show: true }, { num: 4, show: true }, { num: 5, show: false }, { num: 6, show: true }, { num: 7, show: false }, { num:
2020-11-10 23:25:00
715
原创 textarea实现高度自适应的理解
今天遇到个需求:要求 textarea 初始只显示一行,当用户输入内容过多引起换行,或者手动敲回车键换行时,textarea 内容区域自动撑开。 这个简单,于是我敲下大致如下代码: // html <textarea id="codePath" rows="1"></textarea> // js let codePath = document.getElementById('codePath'); codePath.addEventListener('input', funct
2020-11-06 23:53:49
983
3
原创 flex知识回顾
先看几个小栗子: 1、在没有任何样式的情况下,常规布局下,有默认间距: 如果将 input 和 button 的父 div 设置 display: flex,则如下: 2、常规布局下,如果想让按钮局最右边,左边输入框自动填满剩余宽度,会有些麻烦: flex 布局,只需父元素将按钮设置display: flex,input设置 flex: 1 即可: 3、常规布局:想做到图片和输入框无间距同高度,会有些麻烦: flex 布局,只需父元素设置 display: flex 即可: 正文开始: flex
2020-11-05 23:51:12
422
原创 如何编写高质量js代码
本文纯属个人观点,想到什么写什么,自然也有不全面的地方,先流水账似的列一下,后续不定期更新,察觉漏了什么就补上。 1、命名要具有语义化 函数名用动词,比如 function getUserInfo(){ } ,能从名字上大体看出这个函数实现了什么逻辑; 变量用名词,比如 let sex = ‘男’,能从名字上看出这个变量代表什么; 布尔值用 is 开头,比如 let isLoaded = false ,能从名字上看出这个布尔值判断的是什么; 附:变量、对象、数组等在被声明的同时,最好赋一个初始值,字符串
2020-11-04 23:36:50
406
原创 Vue全局组件之install/use
在vue项目里的main.js里,往往会见到vue.use(xx)的写法,比如司空见惯的路由模块: import VueRouter from 'vue-router' Vue.use(VueRouter) 其实路由也就是vue的一个插件,这里被use进来,便成了一个全局组件,全局组件可以在任何地方不需要import而直接使用。 相关知识点:用 install(){ } 和 vue.use() 配合来开发和引入全局组件,在 install(){ } 中vue.component(‘name’, compo
2020-11-03 23:34:16
2025
原创 闭包中return的作用分析
今日有入坑不久的小伙伴表示对闭包中return还不是很理解,这里用个简单的例子说明,先看下面的代码: // html代码 <input type="text" id="name" > // js代码 var input = document.querySelector('#name'); input.addEventListener('input', function () { console.log(this.value) }) 这里没有任何难理解的地方,就是监听input的输入事
2020-11-02 22:58:45
1246
1
原创 基本数据类型和引用数据类型存储的方式及复制
看以下现象: var obj = { a: 2 }; var obj2 = obj1; obj2.a = 3; obj // { a: 3 } obj2 // { a: 3 } 这种现象大家都不陌生,因为obj和obj2指向的是同一个对象,两者相互影响,那如果再往深处挖掘,这是一个什么样的过程呢,这个涉及到栈堆存储的概念。 在js中,按存储方式可将数据类型分为两种:一是基本数据类型(string、number、undefined、null、oolean),二是引用数据类型(object)。 基本数据类
2020-10-31 23:57:27
447
原创 client、offset和scroll的区别和用法
今天在项目中需要获取一个弹出框的实际内容高度,这个没什么问题,用scrollHeight,但是我想到了有两个类似的宽高属性client和scroll,由于用得少,似乎有点淡忘了,在此总结如下: 1、client client系列有4个属性: clientWidth: 元素没被设置宽度,clientWidth = 元素实际宽度 + padding左右内间距 元素被设置宽度,clientWidth = 元素被设置的宽度 + padding左右内间距 clientHeight: 同上,宽度改为高度,padding
2020-10-30 23:59:21
1567
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人