JavaScript中的基本类型包括:数值(Number)、字符串(String)、布尔(Boolean)、null、undefined 和 最新的 ES6 引入的 Symbol。基本类型虽然不是对象,但通过包装对象可以调用方法,这是因为JavaScript临时将它们包装为对应的对象类型,然后在执行方法后再转换回基本类型。例如,字符串基本类型在调用方法时,Javascript 会临时把它转换为 String 对象,从而可以访问到 String.prototype 上定义的方法,如 toLowerCase()
或 indexOf()
。
一、数值类型的方法
JavaScript中数值(Number)基本类型拥有的方法是通过 Number 对象的原型定义的。当一个数值调用这些方法时,JavaScript会将这个数值包装成一个Number对象,从而可以访问这些原型方法。
parseInt 和 parseFloat 是数值类型方法中常用的两个全局函数,而非定义在Number原型上。它们用于解析字符串,返回一个整数或浮点数。
parseInt和parseFloat
let numStr = '123.456';
let intVal = parseInt(numStr); // 123
let floatVal = parseFloat(numStr); // 123.456
parseInt通常用于获取一个字符串开始部分的整数值,而parseFloat用于获取包含小数点的实数值。它们都会忽略字符串后面无法转换成数值的字符。需要注意的是,parseInt有一二参数,第二个参数是转换的基数。
toFixed
数值类型上常用的一个方法是 toFixed()
,它用于格式化数字并返回其字符串表达形式,可以指定小数点后的位数。
let num = 123.456;
let fixedStr = num.toFixed(2); // "123.46"
toExponential
另一个方法是 toExponential()
,它返回数值的指数表示法形式的字符串。
let num = 123.456;
let expStr = num.toExponential(1); // "1.2e+2"
二、字符串类型的方法
字符串(String)类型也有许多方法,这些方法都是定义在String原型上的,当调用这些方法时,基本字符串会被转换成String对象。
charAt和charCodeAt
charAt()
方法返回特定位置的字符,而 charCodeAt()
返回指定索引位置字符的Unicode编码。
let str = 'hello';
let char = str.charAt(0); // "h"
let charCode = str.charCodeAt(0); // 104
indexOf和lastIndexOf
indexOf()
方法返回指定值在字符串中首次出现的索引,如果没有找到就返回-1。与之对应的 lastIndexOf()
方法返回指定值在字符串中最后一次出现的索引。
let str = 'hello world';
let index = str.indexOf('o'); // 4
let lastIndex = str.lastIndexOf('o'); // 7
slice和substring
slice()
方法提取字符串的某个部分,返回一个新字符串,而 substring()
方法则是返回位于String对象两个指定索引之间的子字符串。
let str = 'hello world';
let sliced = str.slice(0, 5); // "hello"
let substringed = str.substring(0, 5); // "hello"
toLowerCase和toUpperCase
toLowerCase()
方法会将字符串转换成小写形式,而 toUpperCase()
将字符串转换成大写形式。
let str = 'Hello World';
let lower = str.toLowerCase(); // "hello world"
let upper = str.toUpperCase(); // "HELLO WORLD"
三、布尔类型的方法
布尔(Boolean)类型表示逻辑实体,可以有两个值:true和false。布尔类型有一个重要的方法:toString()
。
toString
toString()
方法将布尔值转换为字符串 "true" 或 "false"。
let boolTrue = true;
let boolFalse = false;
let strTrue = boolTrue.toString(); // "true"
let strFalse = boolFalse.toString(); // "false"
布尔类型的方法比较少,通常在需要显示或者记录布尔值的信息时使用 toString()
方法。
四、Symbol类型的方法
ES6引入的新原始数据类型Symbol,它是一种唯一且不可变的数据类型,用于生成匿名且唯一的值。Symbol 类型主要用于为对象添加唯一的属性键。Symbol 没有像Number或者String那样的明显方法,但它有一些固有的方法,比如 toString()
和 valueOf()
。
toString和valueOf
let sym = Symbol('description');
let symStr = sym.toString(); // "Symbol(description)"
let symVal = sym.valueOf(); // 返回Symbol本身
五、null和undefined的方法
null
和 undefined
是JavaScript中的两种基本类型,它们代表“没有值”和“缺少值”。它们没有相关的方法和属性,任何尝试访问它们的方法和属性都会导致运行时错误。因此,它们通常在代码中用于检查变量是否已赋值或清楚表达值的缺失状态。
以上便是JavaScript中基本类型的方法。需要强调的是:基本类型的值本身不是对象,所以不会像对象类型那样拥有属性和大量方法。然而,JavaScript为了方便开发者操作基本类型的值,允许我们临时使用对象类型的方法,这正体现了JavaScript的灵活性和强大的表达能力。在编程实践中,合理利用这些方法能够高效、简洁地处理数据。
相关问答FAQs:
1. JavaScript中的基本类型有哪些?它们有哪些常用的方法?
JavaScript中的基本类型包括字符串(string)、数字(number)、布尔值(boolean)、空(null)、未定义(undefined)以及符号(symbol,ES6引入的新类型)。每种基本类型都有一些常用的方法。
2. 如何在JavaScript中使用字符串的方法?
字符串在JavaScript中是一种基本类型,可以使用一系列方法对其进行操作。比如,可以使用toUpperCase()
方法将字符串转换为大写字母,toLowerCase()
方法将字符串转换为小写字母,indexOf()
方法找到字符串中指定字符的位置等等。这些方法可以帮助你在字符串中进行查找、替换、截取等操作。
3. JavaScript中数字类型有哪些常用方法?
数字类型是JavaScript中的另一种基本类型,与字符串不同,数字类型没有像字符串那样丰富的方法。不过,它仍然有一些常用的方法可供使用。例如,toFixed()
方法可以将一个数字四舍五入为指定小数位数的字符串,toString()
方法可以将一个数字转换为字符串,parseFloat()
方法可以将一个字符串解析为浮点数等等。这些方法可以帮助你在数字类型的数据处理中进行格式化、转换等操作。