JavaScript 基础知识 被自己遗忘的

5%10=5
x="5"+"5";
x="5"+5 ;
document.write(x);(結果都為﹕55)

undefined是未初始化的变量的值﹐沒有引用值﹐屬于未定義
var anyway; anyway屬于已定義 有默認空值

一元運算符﹕delete(刪除對開發者定義的對象和方法的引用﹐不能刪除原始的ECMAScript方法)
void 运算符对任何值返回 undefined

没有返回值的函数真正返回的都是 undefined。

一元加法本质上对数字无任何影响。
一元加法计算字符串的方式与 parseInt() 相似
區別﹕只有一元加法才可以對八進制與十六進制形式的字符串(如﹕OxB﹑010)進行轉換

一元减法計算字符串﹐將字符串转换成近似的数字﹐再对该值求负

ECMAScript 整数有两种类型:有符号整数和无符号整数

0 表示正数,1 表示负数
正数是以真二进制形式存储的
负数也存储为二进制代码,采用二进制补码。
计算数字二进制补码﹕絕對值求反加一

在处理有符号整数时,开发者不能访问 31 位。

var iNum = -18;
alert(iNum.toString(2));
输出的是 "-10010"﹐非二进制补码﹐為了避免訪問31位

无符号整数的数值范围为 0 到 4294967295
把无符号整数转换成字符串后,只返回它们的有效位。

位运算 NOT(~)﹐位运算 AND﹐位运算 OR(|)﹐无符号右移运算(>>>)
左移运算(<<)注意:左移运算保留数字的符号位
位运算 XOR由符号(^)表示
只有一个数位存放的是 1 时,它才返回 1
所有整数字面量都默认存储为有符号整数。
只有 ECMAScript 的位运算符才能创建无符号整数。

var iNum1 = 25; //25 等于 00000000000000000000000000011001
var iNum2 = ~iNum1; //转换为 11111111111111111111111111100110
alert(iNum2); //输出 "-26"

<!-- //-->与老的浏览器打交道
/* */多行注释

逻辑 NOT 运算符的行为如下:
* 如果运算数是数字 0,返回 true
* 如果运算数是 0 以外的任何数字,返回 false
* 如果运算数是 null,返回 true
* 如果运算数是 NaN,返回 true
* 如果运算数是 undefined,发生错误
!!sBlue﹐第一个 NOT 运算符返回 Boolean 值。第二个 NOT 将对该 Boolean 值求负

逻辑 AND 运算并不一定返回 Boolean 值:
* 如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
* 如果两个运算数都是对象,返回第二个对象。
* 如果某个运算数是 null,返回 null。
* 如果某个运算数是 NaN,返回 NaN。

与逻辑 AND 运算符相似,如果某个运算数不是 Boolean 值,逻辑 OR 运算并不一定返回 Boolean 值:
* 如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
* 如果两个运算数都是对象,返回第一个对象。
* 如果某个运算数是 null,返回 null。
* 如果某个运算数是 NaN,返回 NaN。

乘法运算符(*)
* 如果结果太大或太小,那么生成的结果是 Infinity 或 -Infinity。
* 如果某个运算数是 NaN,结果为 NaN。
* Infinity 乘以 0,结果为 NaN。
* Infinity 乘以 0 以外的任何数字,结果为 Infinity 或 -Infinity。
* Infinity 乘以 Infinity,结果为 Infinity。

除法运算符(/)
* 如果某个运算数是 NaN,结果为 NaN。
* Infinity 被 Infinity 除,结果为 NaN。
* Infinity 被任何数字除,结果为 Infinity。
* 0 除一个任何非无穷大的数字,结果为 NaN。
* Infinity 被 0 以外的任何数字除,结果为 Infinity 或 -Infinity。

取模运算符(%)
* 如果被除数是 Infinity,或除数是 0,结果为 NaN。
* Infinity 被 Infinity 除,结果为 NaN。
* 如果除数是无穷大的数,结果为被除数。
* 如果被除数为 0,结果为 0。

var bResult = "25" < "3";
两个运算数都是字符串,所以比较的是它们的字符代码,"2" 的字符代码是 50,"3" 的字符代码是 51
var bResult = "25" < 3;
字符串 "25" 将被转换成数字 25,然后与数字 3 进行比较
任何包含 NaN 的关系运算符都要返回 false ("a"<15﹐a調用parseInt() 返回NaN)

等号和非等号用于处理原始值(執行前轉換成數字值),全等号和非全等号用于处理对象
执行类型转换的规则如下:
* 如果一个运算数是 Boolean 值,在检查相等性之前,把它转换成数字值。false 转换成 0,true 为 1(true != 2)
* 如果一个运算数是字符串,另一个是数字,在检查相等性之前,要尝试把字符串转换成数字。("5" == 5)
* 如果一个运算数是对象,另一个是字符串,在检查相等性之前,要尝试把对象转换成字符串。
* 如果一个运算数是对象,另一个是数字,在检查相等性之前,要尝试把对象转换成数字。
遵守下列规则:
* 值 null 和 undefined 相等。
* 在检查相等性时,不能把 null 和 undefined 转换成其他值。(undefined != 0,null != 0)
* 如果某个运算数是 NaN,等号将返回 false,非等号将返回 true。(NaN !=NaN)
* 如果两个运算数都是对象,那么比较的是它们的引用值。如果两个运算数指向同一对象,那么等号返回 true,否则两个运算数不等。

全等号和非全等号(不执行类型转换)

(0)

相关推荐

  • JavaScript基础知识之数据类型

    数据类型 JavaScript中有5种简单数据类型(也称为基本数据类型):Undefined.Null.Boolean.Number和String.还有1种复杂数据类型--Object,Object本质上是由一组无序的名值对组成的. typeof操作符 介于JavaScript是松散类型的,因此需要有一种手段来检测给定变量的数据类型--typeof就是负责提供者方面信息的操作符.对一个值使用typeof操作符可能返回下列某个字符串: ● "undefined"--如果这个值未定义: ●

  • javascript学习笔记(一)基础知识

    基本概念 javascript是一门解释型的语言,浏览器充当解释器. js执行引擎并不是一行一行的执行,而是一段一段的分析执行. 延迟脚本 HTML4.0.1中定义了defer属性,它的用途是表明脚本在执行时不会影响页面的构造.也就是说,脚本会延迟到整个页面都解析完毕后再执行.因此,在<script>元素中设置defer属性,相当于告诉浏览器立即下载,但延迟执行.在XHTML文档中,要把defer属性设置为defer="defer" 异步脚本 html5为<scrip

  • 需要牢记的JavaScript基础知识

    声明(Declarations) undefined值在布尔类型环境中会被当作false. 数值类型环境中undefined值会被转换为NaN. 对一个空变量求值时,空值 null 在数值类型环境中会被当作0来对待,而布尔类型环境中会被当作false JavaScript 变量感觉上是被"提升"或移到了所有函数和语句之前.提升后的变量将返回 undefined 值,所以即使在使用或引用某个变量之后存在声明和初始化操作,这个被提升的引用仍将得到 undefined 值. 由于存在变量声明

  • 7个JS基础知识总结

    1.如何在一个对象上添加属性? 方法一:var b = {};b["name"] = "test";delete b.name 删除对象的属性方法二:b.name ="test";2.如何判断一个变量是否声明?typeof(a) =="undefined"typeof(d) =="function" 是否为函数 3.怎么表示为字符串? 通过双引号(""),单行号(''),反斜杠(//) 

  • JavaScript 语言基础知识点总结(思维导图)

    JavaScript 数组 JavaScript 函数基础 Javascript 运算符 JavaScript 流程控制 JavaScript 正则表达式 JavaScript 字符串函数 JavaScript 数据类型 JavaScript 变量 Window 对象 DOM 基本操作    由于上面的图片比较大,建议大家下载到本地查看

  • javascript之正则表达式基础知识小结

    元字符 ^ $ . * + ? = ! : | \ / ( ) [ ] { } 在使用这些符号时需要用"\"来进行转移. 如果记不清楚那些标点符号需要转移,可以在使用标点符号时都使用反斜杠"\" 简单匹配 1.直接量 /javascript/ 匹配带有"javascript"的字符串 比如"javascript is an object-oriented scripting language" 2.[ ] /[abc]/ 匹配

  • Angularjs基础知识及示例汇总

    angularjs是google开发的一款高大上的前端mvc开发框架. Angularjs官网:https://angularjs.org/ 官网有demo,访问可能需要FQ Angularjs中国社区:http://www.angularjs.cn/ 适合初学者 引用文件:https://ajax.googleapis.com/ajax/libs/angularjs/1.3.8/angular.min.js 使用angular注意 引用angularjs库:https://github.com

  • javascript真的不难-回顾一下基础知识

    前言 说Jquery之前,先来学习一下Javascript(以后简称为JS)语言中的基础知识问题,其时对于每种编程语言来说基础知识都是大同小异的,对变量,函数,条件语句块,循环语句块等等,而对于每种语言在写法上到是显得各有不同,如JS里在定义变量时,你要用var去声局部变量的声明,而对于弱类型的语言JS来说,你也可以不加var,但不加它会认为这个变量为全局变量,这是要注意的. 变量 在程序运行过程中,其值可以发生改变的(呵呵,10多年前书上的定义) var people ; //声明一个名为pe

  • extjs 学习笔记(一) 一些基础知识

    我在项目中已经频繁使用了jquery,这次主要是学习使用extjs,但现有的教程基本都是针对2.0的,而且后台用到的语言也很少是.net平台下的C#,所以我打算针对3.0版,后台使用C#,记录下自己的学习过程,希望能和志同道合的朋友一起探讨,共同进步. extjs的官方网站是http://www.extjs.com,目前最高版本是3.0.2,但是只有3.0.0的才没有任何下载限制,可以点击这里下载3.0版的.下载来的压缩包里边包含压缩后的extjs库,调试时用到的库,具有可读性的源代码,文档和例

  • javascript DOM 操作基础知识小结

    DOM添加元素,使用节点属性 DOM添加元素,使用节点属性 //涂聚文 geovindu@163.com var nr = 1; function addItem() { var list = document.getElementById("list"); var newNode = document.createElement("li"); var newLink = document.createElement("a"); newLink.

随机推荐