<script>
// 3字符串的使用
var x="214234";
var y="cxk";
// 想要在字符串内部既包含单引号''又包含双引号"用转义字符\来标识,
console.log("\"cxk\'s age\'s 18\"");
document.write("\"cxk\'s age\'s 18\"");
// 转义字符\可以转义很多字符,比如\n表示换行,
// \t表示制表符,字符\本身也要转义,所以\\表示的字符就是\。
// 由于多行字符串用\n写起来比较费事,所以最新的ES6标准新增了一种多行字符串的表示方法,用反引号``表示:
var s=
`这是一个
多行
字符串`;
document.write(s);
// 下面这种用单引号表述是错误的
// var ss='
// 这是一个错误
// '
// 3.1模板字符串
// 要把多个字符串连接起来,可以用+号连接:
let name1 = '小明';
let age1 = 20;
let message1 = '你好, ' + name + ', 你今年' + age + '岁了!';
document.write(message1);
// 如果有很多变量需要连接,用+号就比较麻烦。ES6新增了一种模板字符串,表示方法和上面的多行字符串一样,但是它会自动替换字符串中的变量:
let name2 = '小明';
let age2 = 20;
let message2 = `你好, ${name}, 你今年${age}岁了!`;
document.write(message2);
// 3.2操作字符串
// 要获取字符串某个指定位置的字符,使用类似Array的下标操作,索引号从0开始:
var s = 'Hello, world!';
s[0]; // 'H'
s[6]; // ' '空格占了一个字符
s[7]; // 'w'
s[12]; // '!'
s[13]; // undefined 超出范围的索引不会报错,但一律返回undefined
// 不能对s[0]='1'赋值没有效果
// s[0]; // 'H'不会变
// 和字符串使用有关的一些方法(了解即可)
// toUpperCase
// toUpperCase()把一个字符串全部变为大写:
var s = 'Hello';
s.toUpperCase(); // 返回'HELLO'
// toLowerCase
// toLowerCase()把一个字符串全部变为小写:
var s = 'Hello';
var lower = s.toLowerCase(); // 返回'hello'并赋值给变量lower
// lower; // 'hello'
// indexOf()
// 会搜索指定字符串出现的位置:
var s = 'hello, world';
s.indexOf('world'); // 返回7
// substring
// substring()返回指定索引区间的子串:
var s = 'hello, world'
s.substring(0, 5); // 从索引0开始到5(不包括5),返回'hello'
s.substring(7); // 从索引7开始到结束,返回'world'
</script>