原生js杂谈

栏目: JavaScript · 发布时间: 5年前

内容简介:前端基础可谓非常重要,这一篇是我对一些原生js的概念和使用上的一些小记录,也就是一些原生js的杂谈,看博文的同学,希望我们可以互相交流哈哈哈使用toString()方法进行判断,toString方法是写在Object原型上的,也就是说在默认情况下每一个Object对象都会继承toString方法,如果此方法没有在自定义对象里被覆盖,那么toString返回的是[object type],type就是该对象的类型,那么我们使用.call()或者.apply()的调用方式就可以在不同对象类型上使用这个toStr

前端基础可谓非常重要,这一篇是我对一些原生js的概念和使用上的一些小记录,也就是一些原生js的杂谈,看博文的同学,希望我们可以互相交流哈哈哈

正文

判断对象的类型

使用toString()方法进行判断,toString方法是写在Object原型上的,也就是说在默认情况下每一个Object对象都会继承toString方法,如果此方法没有在自定义对象里被覆盖,那么toString返回的是[object type],type就是该对象的类型,那么我们使用.call()或者.apply()的调用方式就可以在不同对象类型上使用这个toString,比如下面toString().call(val),这里的toString()是Object.prototype.toString,这样我再进行一些替换和切分操作就可以获得对象的type

let val = new Date()
toString.call(val).replace(/[\[\]]/g,'').split(' ')[1].toLowerCase()
复制代码

一个更新states的块

(function () {
  //状态
  const states = {
    a: null,
    b: {}
  }
  //获取对应属性的值
  function get(name) {
    return states.mame
  }
  //获取states对象
  function getStates() {
    return states
  }
  //判断对象类型
  function type(elem) {
    if (elem == null) {
      return elem + ''
    }
    return toString.call(elem).replace(/[\[\]]/, '').split(' ')[1].toLowerCase()
  }
  //设置或更新states
  function set(options, target) {
    const keys = Object.keys(options)
    let o = target ? target : states
    keys.map(item => {
      if (o[item] === undefined) {
        o[item] = options[item]
      } else {
        type(o[item]) == 'object' ? set(options[item], o[item]) : o[item] = options[item]
      }
      return item
    })
  }
  //通过外部环境保持引用变为公用方法
  window.get = get
  window.getStates = getStates
  window.set = set
})();
set({
  a: 1,
  b: {
    name: 'joe',
    age: 24
  }
})
console.log(getStates())
复制代码

url转码

解码 decodeUrlComponent 打码 encodeUrlComponent

数组操作

.pop()删除数组最后一个值,返回被删除的值 .shift()删除数组第一个值,返回被删除!!的值 .push() 在数组最后添加一个值,返回数组长度 .unshift() 在数组最前面添加一个值,返回数组长度 不改变原来数组:slice(),join(),concat() 改变原来数组:pop(),push(),shift(),unshift(),reverse(),splice()

运算符+的转换

今天在群里有同学提问一个问题,题目是[+[]][+[]]的结果是多少,这个就要联系到+号运算符的隐式转换,在一元运算符中使用加法运算时会把加号后面的值转化成Number类型

Number([])//0
[+[]][+[]] => [0][0] => 0
复制代码

forEach、map、reduce、filter

forEach是遍历数组每一项的值,然后让每个值都执行一次回调函数,会改变原数组 map 是对数组每一项进行操作,然后返回一个新的数组,,不改变原数组 reduce 是利用递归的原理对所有数值进行操作返回一个值 filter 是把符合条件的数值给挑选出来,返回一个新数组,不改变原数组,新数组的值是浅拷贝也就是引用传递,可以通过filter来筛选出想操作的值,然后直接对返回的数组进行操作

set结构做数组去重

非常简单的方法,直接将数组转化成set结构,然后再将set结构转为数组,Array.from可以将set结构转化为数组结构,当然也可以直接用解构的方式[...new Set(array)]

//去重函数
function dedupe (array) {
  return Array.from(new Set(array))
}
复制代码

以上所述就是小编给大家介绍的《原生js杂谈》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

游戏引擎架构

游戏引擎架构

[美] Jason Gregory (杰森.格雷戈瑞) / 叶劲峰 / 电子工业出版社 / 2014-1 / 128.00元

《游戏引擎架构》同时涵盖游戏引擎软件开发的理论及实践,并对多方面的题目进行探讨。本书讨论到的概念及技巧实际应用于现实中的游戏工作室,如艺电及顽皮狗。虽然书中采用的例子通常依据一些专门的技术,但是讨论范围远超于某个引擎或API。文中的参考及引用也非常有用,可让读者继续深入游戏开发过程的任何特定方向。 《游戏引擎架构》为一个大学程度的游戏编程课程而编写,但也适合软件工程师、业余爱好者、自学游戏程......一起来看看 《游戏引擎架构》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具