JavaScript 基础知识 被自己遗忘的


Posted in Javascript onOctober 15, 2009

5%10=5
x="5"+"5";
x="5"+5 ;
document.write(x);(?果都?椹s55)

undefined是未初始化的变量的值??]有引用值??儆谖炊?x
var anyway; anyway?儆谝讯?x 有默?空值

一元?算符?delete(?h除?﹂_?者定?的?ο蠛头椒ǖ囊?茅o不能?h除原始的ECMAScript方法)
void 运算符对任何值返回 undefined

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

一元加法本质上对数字无任何影响。
一元加法计算字符串的方式与 parseInt() 相似
?^?e?只有一元加法才可以?Π诉M制?十六?制形式的字符串(如?OxB?010)?行??Q

一元减法?算字符串??⒆址???怀山?频氖?蜘o再对该值求负

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

0 表示正数,1 表示负数
正数是以真二进制形式存储的
负数也存储为二进制代码,采用二进制补码。
计算数字二进制补码???χ登蠓醇右

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

var iNum = -18;
alert(iNum.toString(2));
输出的是 "-10010"?非二进制补码??榱吮苊庠L??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)

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

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

Javascript 相关文章推荐
简单的js表单验证函数
Oct 28 Javascript
jquery ajax跨域解决方法(json方式)
Feb 04 Javascript
jquery用offset()方法获得元素的xy坐标
Sep 06 Javascript
使用javascript实现json数据以csv格式下载
Jan 09 Javascript
基于JS实现省市联动效果代码分享
Jun 06 Javascript
BootStrap智能表单实战系列(十一)级联下拉的支持
Jun 13 Javascript
基于jQuery实现Tabs选项卡自定义插件
Nov 21 Javascript
详解Angular的内置过滤器和自定义过滤器【推荐】
Dec 26 Javascript
微信小程序组件 marquee实例详解
Jun 23 Javascript
使用AngularJS对表单提交内容进行验证的操作方法
Jul 12 Javascript
vue表单中遍历表单操作按钮的显示隐藏示例
Oct 30 Javascript
Vue打包部署到Nginx时,css样式不生效的解决方式
Aug 03 Javascript
javascript 操作cookies及正确使用cookies的属性
Oct 15 #Javascript
extjs 学习笔记(三) 最基本的grid
Oct 15 #Javascript
JavaScript Array扩展实现代码
Oct 14 #Javascript
JavaScript 动态创建VML的方法
Oct 14 #Javascript
JavaScript读取中文cookie时的乱码问题的解决方法
Oct 14 #Javascript
jQuery 标题的自动翻转实现代码
Oct 14 #Javascript
JavaScript 替换Html标签实现代码
Oct 14 #Javascript
You might like
Trying to clone an uncloneable object of class Imagic的解决方法
2012/01/11 PHP
修改ThinkPHP缓存为Memcache的方法
2014/06/25 PHP
php检查是否是ajax请求的方法
2015/04/16 PHP
详解PHP的Yii框架中组件行为的属性注入和方法注入
2016/03/18 PHP
ThinkPHP中order()使用方法详解
2016/04/19 PHP
php实现微信公众平台发红包功能
2018/06/14 PHP
php利用array_search与array_column实现二维数组查找
2019/07/08 PHP
PHP如何通过date() 函数格式化显示时间
2020/11/13 PHP
给Flash加一个超链接(推荐使用透明层)兼容主流浏览器
2013/06/09 Javascript
JavaScript DOM 学习总结(五)
2015/11/24 Javascript
高效利用Angular中内置服务$http、$location等
2016/03/22 Javascript
JS简单实现DIV相对于浏览器固定位置不变的方法
2016/06/17 Javascript
浅谈Node.js:理解stream
2016/12/08 Javascript
JavaScript实现垂直滚动条效果
2017/01/18 Javascript
在vue项目中,使用axios跨域处理
2018/03/07 Javascript
Vue实现table上下移动功能示例
2019/02/21 Javascript
如何在微信小程序中存setStorage
2019/12/13 Javascript
JS如何判断对象是否包含某个属性
2020/08/29 Javascript
[46:14]VGJ.T vs Liquid 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
Python中规范定义命名空间的一些建议
2016/06/04 Python
Python3处理HTTP请求的实例
2018/05/10 Python
python使用opencv实现马赛克效果示例
2019/09/28 Python
Django框架配置mysql数据库实现过程
2020/04/22 Python
Python urllib2运行过程原理解析
2020/06/04 Python
Selenium alert 弹窗处理的示例代码
2020/08/06 Python
CSS3 开发工具收集
2010/04/17 HTML / CSS
JD Sports德国官网:英国领先的运动鞋和运动服饰零售商
2018/02/26 全球购物
Baracuta官方网站:Harrington夹克,G9,G4,G10等
2018/03/06 全球购物
保加利亚运动鞋购物网站:SneakerStudio.bg
2020/12/23 全球购物
酒店前台接待岗位职责
2013/12/03 职场文书
公司培训欢迎词
2014/01/10 职场文书
端午节粽子促销活动方案
2014/02/02 职场文书
我的中国梦口号
2014/06/16 职场文书
python 网络编程要点总结
2021/06/18 Python
Redis 持久化 RDB 与 AOF的执行过程
2021/11/07 Redis
《王者天下》第4季首话新剧照 4月9日正式开播
2022/04/07 日漫