首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    深入解析Underscore.js源码架构

    Underscore.js是很有名的一个工具库,我也经常用他来处理对象,数组等,本文会深入解析Underscore源码架构,跟大家一起学习下他源码的亮点,然后模仿他写一个简单的架子来加深理解。...不用new的构造函数 我们在使用第三方库的时候,经常需要先拿一个他们的实例,有些库需要用new来显式的调用,比如原生的Promise,有些库不需要new也可以拿到实例对象,比如jQuery。...另外还模仿jQuery的这种方案实现了我自己的一个工具库:学以致用:手把手教你撸一个工具库并打包发布,顺便解决JS小数计算不准问题。...new _()也会调到_()方法,但是因为使用new调用,里面的this指向的就是new出来的实例,所以if进不去,执行结束。...具体流程如下: 取出参数里面的函数属性,将其塞入一个数组 遍历这个数组,将里面的每个项设置到原型上 设置原型的时候注意处理下实例方法和静态方法的参数 下面来看看代码: _.mixin = function

    57131

    js数组push方法使用注意

    js 数组的push方法,想必大家都知道是向数组末尾添加元素,但是有一个很关键的点需注意: 引自 MDN 返回值 当调用该方法时,新的 length 属性值将被返回。...push之后返回的是length,而不是新的数组,如果不清楚这点,在使用过程中回遇到很大的坑。...顺带记一下其他几个数组的方法返回值: pop() pop()方法从数组中删除最后一个元素,并返回该元素的值。此方法更改数组的长度。...此方法不会更改现有数组,而是返回一个新数组。...如果没有删除元素,则返回空数组。 slice() slice() 方法返回一个从开始到结束(不包括结束)选择的数组的一部分浅拷贝到一个新数组对象,原始数组不会被修改。

    4.9K60

    使用js替换数组中元素

    js替换数组元素 记得我最近刚刚做的一个项目,后端返回的一个数组对象,里面的图片的地址有问题,一个在这个ip上一个在另一个ip 上,我问他咋办,他说,你要自己把那个返回的数据重新修改一下就是下面这种...{ a: "http:192.168.2.158/img/56", b: 'kkk3', c: 'test' } ] 思路是这样的,先定义一个空数组...,然后循环当前数组,然后得到当前的ip 地址, 然后再push 进入一个空数组,然后返回 好了先补充一个知识点,就是如何获取得到当前ip地址,首先: var data=new URL(“a...”) 要new 一个对象,然后下面这个是实际操作代码,我们能用生js 实现,react,或者vue 你们肯定也就知道咋操作了,不懂可以留言问我 <!...; window.location.pathname; window.location.protocol; window.location.port //端口 //替换数组中的某个键

    11.7K20

    vue.js过滤器的基本使用

    过滤器分为两种: 全局过滤器 自定义过滤器 使用过滤器,我们可以对数据进行格式化处理 过滤器 具体代码 代码解析: 全局过滤器 Vue.filter('formatMsg', function (msg.../g, arg); }); Vue.filter('formatAgain', function (msg, arg) { return msg + ",然而我还是很想念她"; }); 自定义过滤器...app", data: { msg: '我的生涯一片无悔,我想起那天夕阳下的奔跑,那是我逝去的青春' }, filters: { // 定义私有的过滤器...test: function (msg) { return msg + ", 青涩美好又有些疼痛的青春"; } } }) 注意: 过滤器可以多层引用...,多个过滤器用管道符 | 隔开 当全局过滤器与自定义过滤器同名时,优先使用自定义过滤器 如想了解更多的vue实例,请查阅我的vue笔记目录

    1.7K50

    js数组方法,常用数组Api的基本使用

    console.log(arr) [20,30,40] 6 slice() 查找数组中选定范围的值 返回值是一个数组 不会改变原来的数组 该方法有两个参数 slice( start...] 9 unshift(): 将参数添加到原数组开头,并返回数组的长度 , 会改变原数组 var arr = [1,2,3,4] arr.unshift(0) // 5 console.log(arr...console.log(arr.indexOf(60)) // -1 12 forEach() 对数组进行遍历循环,对数组中的每一项运行给定函数。...if(item>2) return item }); console.log(arr2) //  [undefined, undefined, 3, 4, 5] 14 filter() 对数组符合条件的每一项进行过滤...return item } }) console.log(arr2) // [20, 30, 40] 15 flat() 方法会按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回

    2.5K10
    领券