零散的JS和node.js小知识

时间:2022-01-16 17:04:32

JS的连续赋值和曾经出现的怪异情况

let a=1;
let b=a=3;

如上的真实赋值过程 => a=1 => a=3 => b=3 => 一般来说,等号是从右向左赋值的

于是问题来了

var a={n:1};
var b=a;
a.x=a={n:2};
console.log(a) // {n:2}
console.log(b) // {n:1,x:{n:2}}
console.log(a.x) // undefined
console.log(b.x) // {n:2}

a={n:1} => b={n:1} =>

在JS中,若是'.'和'='同时还出现,先进行'.'操作

于是乎,没有先执行右边的赋值,而是先执行了给 a 增加 x 属性这一操作

=> a.x={n:2} 在这里的时候a={n:1,x:{n:2}} =>

这时候 a指向了 {n:2} ,a变了,a被重新复制了,天地变化。

(因为这里a变成了{n:2}所以结局问a.x是没有这个属性的)

=> 由于b一直都是a的镜子,跟随着a的变化,直到a不再指向那个地址

参考文章:http://www.jb51.net/article/118168.htm


0.1+0.2=0.3???错!!它会等于 0.3000000000000004 (大概这么多0,因为小小的摄入误差) 这并非只是ES一家错误。 但是 0.15+0.25等其他的是正确的。

a=0.1;
b=0.2;
console.log(a+b); // 0.30000000000004

NaN存在的意义?

在其他编程语言中,任何数值除以非数值都会导致错误,从而导致代码停止执行,而在ES中,任何数值除以非数值会返回NaN,因为不会导致代码停止。

a=0.1;
b=0.2;
console.log(a/'hhh'); // NaN

获取成员属性应该用'.'还是用[]

这个见仁见智,具体细节曾经百度过但是现在已经淡忘,只记得速度差异忽略不计

不过用.有一个好处,那就是更加紧凑而且可读性比较好


||&&的妙用

在对象中,运算符 || 可以用来填充默认值: let height= variable || 100

在对象中,运算符 && 可以帮我们来规避 undefined 出的异常(因为冲undefined中取值会报异常) : let height= obj && obj.length


JS基础知识之 addEventListener

该方法用于给我们选取的元素添加各种 dom 相关的事件。诸如 onclick,onmousemove 等。

需要注意的地方,该方法格式中不需要加 on,以下为具体案例

	div1.addEventListener('click',function(event){
console.log("A");
});

但是我想说的其实是,关于它的其他参数

它有三个参数,分别是: 1.事件名称、种类 2.定义的回调函数 3.事件是否在捕获阶段,冒泡阶段执行

关于第三个参数,它是一个 bool 值。

true - 事件句柄在捕获阶段执行

false- false- 默认。事件句柄在冒泡阶段执行

关于事件的几个阶段:http://blog.csdn.net/jquery_qq/article/details/51448842

一直没有怎么注意效率和写法,最近做了个react-todo2.0发现优化的地方太多了,看见redux官网的todo-list更觉写法简明,于是最近都特别在意代码风格。

代码比较1:

            contents = JSON.parse(contents);
this.props.initTodos(contents);



this.props.initTodos(JSON.parse(contents))

哪一种写法更高效?

setInterval的初始值从1开始。 比如 const a = setInterval(()=>{}, 3000) ,这里的a值为1.

零散的JS和node.js小知识的更多相关文章

  1. .NET程序员也学Node.js——初识Node.js

    清明在石门休了八天假,一眨眼,4月又到中旬了...看到.NET在天朝彻底沦陷而又无能为力,我开始尝试去学习一些新的东西来充实自己,我自然是打死不会去学java的,没有为什么,于是乎,最近开始学习一些前 ...

  2. 如何在vscode里面调试js和node.js

    一般大家调试都是在浏览器端调试js的,不过有些时候也想和后台一样在代码工具里面调试js或者node.js,下面介绍下怎样在vscode里面走断点. 1,用来调试js 一:在左侧扩展中搜索Debugge ...

  3. Angular、React.js 和Node.js到底选谁?

    为了工作,程序员选择正确的框架和库来构建应用程序是至关重要的,这也就是为什么Angular和React之间有着太多的争议.Node.js的出现,让这场战争变得更加复杂,虽然有选择权通常是一件很棒的事情 ...

  4. 极简 Node.js 入门 - Node.js 是什么、性能有优势?

    极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...

  5. Node.js入门-Node.js 介绍

    Node.js 是什么 Node.js 不是一种独立的语言,与 PHP,Python 等"既是语言优势平台"不同,它也不是一个 JavaScrip 框架,不同于 CakePHP,D ...

  6. KoaHub.JS用于Node.js的cron作业调度程序代码

    node-schedule A cron-like and not-cron-like job scheduler for Node. Node Schedule     Announcement:  ...

  7. KoaHub.JS用于Node.js的可移植Unix shell命令程序代码

    shelljs Portable Unix shell commands for Node.js ShellJS - Unix shell commands for Node.js     Shell ...

  8. KoaHub.JS基于Node.js开发的mysql的node.js驱动程序代码

    mysql A node.js driver for mysql. It is written in JavaScript, does not require compiling, and is 10 ...

  9. KoaHub.JS基于Node.js开发的Koa 生成验证码插件代

    ccap node.js generate captcha using c++ library CImg without install any other lib or software node- ...

  10. 浏览器中的 JS 和 Node.js 中的 JS

    一个是前端技术,一个是后端技术 浏览器中的 JavaScript ECMAScript  语言基础,如语法.数据类型结构.一些内置对象 BOM(Browser Object Model)  一些操作页 ...

随机推荐

  1. react+redux官方实例TODO从最简单的入门(5)-- 查

    上一篇文章<改>实现了,最后一个功能--<查>! 这个查是稍微要复杂一点的功能,官方实现的就是一个过滤数组的效果,然后展示出来,这里有3个状态,all,completed,ac ...

  2. 学习微信小程序之css4设置颜色&comma;单位表示,字体样式

    颜色的设置可以通过RGB设置 可以直接通过英文单词设置 可以通过16进制来设置 长度单位: 字体样式: 设置字体样式 字体粗细 设置字体风格 设置字间距

  3. ElasticSearch问题记录

    1.Young GC导致集群master重新选举,一台server fail [2016-12-10 07:38:24,546][WARN ][transport ] [BFRD_1] Receive ...

  4. &lbrack;Asp&period;net 开发系列之SignalR篇&rsqb;专题四:使用SignalR实现发送图片

    一.引言 在前一篇博文已经介绍了如何使用SignalR来实现聊天室的功能,在这篇文章中,将实现如何使用SignalR来实现发送图片的功能. 二.实现发送图片的思路 我还是按照之前的方式来讲述这篇文章, ...

  5. python合并2个字典

    2种方式,update()和items()方式 In [14]: a Out[14]: {'a': 1, 'b': 2, 'c': 3} In [15]: c = {'d': 4} In [16]: ...

  6. Spring管理 hibernate 事务配置的五种方式

    Spring配置文件中关于事务配置总是由三个组成部分,DataSource.TransactionManager和代理机制这三部分,无论是那种配置方法,一般变化的只是代理机制这块! 首先我创建了两个类 ...

  7. Spring初始化 Map 和 解析Json value

    单独定义Map数据结构的bean: <bean id= "expToLevelMap" class="org.springframework.beans.facto ...

  8. JSON字符串和js对象转换

    https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON js数据类型: 字符串.数字 ...

  9. JavaScript高级程序设计47&period;pdf

    触摸设备 iOS和Android设备的实现非常特别,因为这些设备没有鼠标,在面向iPhone和iPod中的Safari开发时,要记住以下几点 不支持dblclick事件,双击浏览器窗口会放大画面,没有 ...

  10. 转载微信公众号 测试那点事:Jmeter乱码解决

    原文地址: http://mp.weixin.qq.com/s/4Li5z_-rT0HPPQx9Iyi5UQ  中文乱码一直都是比较让人棘手的问题,我们在使用Jmeter的过程中,也会遇到中文乱码问题 ...