javascript学习(二)— 字符串
来源:互联网 发布:企业即时通讯软件 编辑:程序博客网 时间:2024/06/07 16:28
字符串
JavaScript的字符串就是用 ’ ’ 或 ” ” 括起来的字符表示。
如果 ’ 本身也是一个字符,那就可以用 ” ” 括起来,比如 “I’m OK” 包含的字符是I,’,m,空格,O,K这6个字符。
如果字符串内部既包含 ’ 又包含 ” 怎么办?可以用转义字符\来标识,比如:
'I\'m \"OK\"!';
表示的字符串内容是:I’m “OK”!
转义字符\可以转义很多字符,比如\n表示换行,\t表示制表符,字符\本身也要转义,所以\表示的字符就是\。
ASCII字符可以以\x##形式的十六进制表示,例如:
'\x41'; // 完全等同于 'A'
还可以用\u####表示一个Unicode字符:
'\u4e2d\u6587'; // 完全等同于 '中文'
多行字符串
由于多行字符串用\n写起来比较费事,所以最新的ES6标准新增了一种多行字符串的表示方法,用反引号 ...
表示:
注意:反引号在键盘的ESC下方,数字键1的左边:
alert(`这是一个多行字符串`);
模板字符串
要把多个字符串连接起来,可以用+号连接:
var name = '小明';var age = 20;var message = '你好, ' + name + ', 你今年' + age + '岁了!';alert(message);
如果有很多变量需要连接,用+号就比较麻烦。ES6新增了一种模板字符串,表示方法和上面的多行字符串一样,但是它会自动替换字符串中的变量:
var name = '小明';var age = 20;var message = `你好, ${name}, 你今年${age}岁了!`;//注意:使用的是反引号alert(message);
操作字符串
字符串常见的操作如下:
var s = 'Hello, world!';console.info(s.length); // 13
要获取字符串某个指定位置的字符,使用类似Array的下标操作,索引号从0开始:
var s = 'Hello, world!';console.info(s[0]); // 'H's[6]; // ' 's[7]; // 'w's[12]; // '!'s[13]; // undefined 超出范围的索引不会报错,但一律返回undefined
需要特别注意的是,字符串是不可变的,如果对字符串的某个索引赋值,不会有任何错误,但是,也没有任何效果:
var s = 'Test';s[0] = 'X';alert(s); // s仍然为'Test'
常用方法
JavaScript为字符串提供了一些常用方法,注意,调用这些方法本身不会改变原有字符串的内容,而是返回一个新字符串:
toUpperCase
toUpperCase()把一个字符串全部变为大写:
var s = 'Hello';console.info(s.toUpperCase()); // 返回'HELLO'
toLowerCase
toLowerCase()把一个字符串全部变为小写:
var s = 'Hello';var lower = s.toLowerCase(); // 返回'hello'并赋值给变量lowerconsole.info(lower); // 'hello'
indexOf
indexOf()会搜索指定字符串出现的位置:
var s = 'hello, world';console.info(s.indexOf('world')); // 返回7console.info(s.indexOf('World')); // 没有找到指定的子串,返回-1
substring
substring()返回指定索引区间的子串:
var s = 'hello, world'console.info(s.substring(0, 5)); // 从索引0开始到5(不包括5),返回'hello'console.info(s.substring(7)); // 从索引7开始到结束,返回'world'
- javascript学习(二)— 字符串
- JavaScript学习笔记二:字符串
- JavaScript基础(二)--字符串
- JavaScript学习(二)
- 学习JavaScript(二)
- JavaScript学习(二)
- JavaScript学习(二)
- JavaScript学习(二)
- JavaScript学习(二)
- JavaScript学习(二)
- JavaScript学习(二)
- JavaScript学习(二)
- Javascript学习(二)——事件
- JavaScript——学习笔记(二)
- JavaScript学习(二)——javascript prompt的使用
- JavaScript学习笔记(二)——客户端JavaScript
- JavaScript 字符串(String)对象(二十四)
- javascript字符串api(二)
- 利用sql插入&符号到Oracle会出错解决办法
- 视频解码同步
- Nginx的负载均衡的那点事
- 笨办法12提示别人
- [札记]SSM开发框架集成问题,Spring4.3.x+Mybatis3.4.x+SpringMVC集成时遇到的jason转换问题
- javascript学习(二)— 字符串
- 栈
- Android组件
- Volley源码初读
- python_代码
- hi
- 修改一个表中的字段等于另一个表中字段
- 联合体的存放顺序问题
- 58 同城 iOS 客户端组件化演变思路整理