JavaScript学习笔记之创建字符串比较
2010-02-27 23:26
507 查看
在Javascript中声明一个字符串,我们可以方便的使用literal(字面)语法:
var str1 = 'Hello Javascript!';
var str2 = "Hello World!";
由于在Javascript中,任何事物都是对象,所以我们也可以使用new语法创建:
var str3 = new String("Hello Javascript!");
var str4 = new String("Hello World!");
现在的问题是,这两种方法创建字符串是否等价呢?
str1 == str3 // true
typeof(str1) == 'string' // true
typeof(str3) == 'object' // true
typeof(str3.toString()) == 'string' // true
可见,new字符串和literal字符串使用 == 比较是相等的,但是他们属于不同的类型。
在Javascript中可以使用 === 来比较两个变量是否严格相等(不仅字面值相等,而且类型相等)。
str1 === str3 // false
这里要注意,使用==进行判断时,Javascript会自动进行类型转换,有时会产生让人奇怪的结果:
12 == '12' // true
12 === '12' // false
这也就是为什么 JSLint 推荐的使用 === 而不是使用 == 进行变量判断的原因。
转自:/article/4676552.html
var str1 = 'Hello Javascript!';
var str2 = "Hello World!";
由于在Javascript中,任何事物都是对象,所以我们也可以使用new语法创建:
var str3 = new String("Hello Javascript!");
var str4 = new String("Hello World!");
现在的问题是,这两种方法创建字符串是否等价呢?
str1 == str3 // true
typeof(str1) == 'string' // true
typeof(str3) == 'object' // true
typeof(str3.toString()) == 'string' // true
可见,new字符串和literal字符串使用 == 比较是相等的,但是他们属于不同的类型。
在Javascript中可以使用 === 来比较两个变量是否严格相等(不仅字面值相等,而且类型相等)。
str1 === str3 // false
这里要注意,使用==进行判断时,Javascript会自动进行类型转换,有时会产生让人奇怪的结果:
12 == '12' // true
12 === '12' // false
这也就是为什么 JSLint 推荐的使用 === 而不是使用 == 进行变量判断的原因。
转自:/article/4676552.html
相关文章推荐
- 前端学习笔记1---HTML meta简介、JavaScript简介创建对象--待完善
- 声明字符串"javascript学习笔记,String字符串相关:
- anychart学习笔记之一javaScript中创建anychart
- php——学习笔记,比较字符串
- javascript面向对象学习笔记(二)——创建对象
- 【转】shell学习笔记(三)——引用变量、内部变量、条件测试、字符串比较、整数比较等
- JavaScript 学习笔记(七)字符串的连接
- JavaScript学习笔记--第一章.变量与字符串
- javascript创建对象学习笔记
- JavaScript学习笔记(二十四) 模块创建构造函数
- JavaScript-DOM学习笔记之动态创建标记
- JavaScript学习笔记29-其他的创建数组的方法
- 【JavaScript】学习笔记(对象的访问,创建;for-in循环)
- JavaScript基础学习笔记(三)——JavaScript 比较和逻辑运算符、JavaScript If...Else 语句、JavaScript Switch 语句
- 韩顺平 javascript教学视频_学习笔记13_类和对象细节_创建对象的几种方式_js对象内存分析
- JavaScript DOM编程 学习笔记-创建并接入节点
- 比较详细的javascript DOM 学习笔记
- JavaScript 学习笔记(七)字符串的连接
- JavaScript学习笔记之浅析几种创建对象的方法