javascript里字符串方法解析

	// 1.charAt(num):返回对应字符串索引的内容。
    // var str = "我是老天爸爸最爱的崽"
    // console.log(str.charAt(1)) //是
    // console.log(str.charAt(-1)) //无,因为索引没有负数

    // 2.charCodeAt(num):返回对应的字符串索引的内容的unicode编码
    // var str = "我是老天爸爸最爱的崽"
    // console.log(str.charCodeAt(1)) //26159
    // console.log(str.charCodeAt(-1)) //NaN,因为索引对应的是null,则不是一个数

    // 3.String.fromCharCode(unicode编码);将参数中的unicode编码返回成对应的字符串的内容,多个编码用逗号分隔。
    // console.log(String.fromCharCode(26159)) //是

    //4. trim() 创建一个字符串的副本,删除前置及后缀的所有空格,然后返回结果,但是中间的空格不去除
    // var str = "  1  23"
    // console.log(str.trim())//1  23

    //5. replace() 替换,这个方法接受两个参数:第一个参数可以是一个 RegExp 对象或者一个字符串,第二个参数可以是一个字符串或者一个函数。如果第一个参数是字符串,那么只会替换第一个子字符串。如果想把其他的也替换可以用遍历
    // var str = "abcdefg"
    // console.log(str.replace("c", "*")) //ab*defg ,前面写要被替换的字符,第二个参数写用什么替换

    // 6.split——根据分隔符、将字符串拆分成数组。**有两个参数,第二个参数可以省略,他代表截取的长度,超过长度的不要;**只能用字符串内有的分隔,或者“”这样就是使用逗号分隔
    // var str = "123456"
    // console.log(str.split()) //["123456"]
    // console.log(str.split("")) //["1", "2", "3", "4", "5", "6"]
    // console.log(str.split(",")) //["123456"]

    // var arr = [1, 2, 3, 4, 5, 6]
    // console.log(arr.join()) //1,2,3,4,5,6
    // console.log(arr.join("")) //123456
    // console.log(arr.join(",")) //1,2,3,4,5,6
    // console.log(arr.join("*")) //1*2*3*4*5*6

    // 7.substring():用来截取字符串的内容
    // 没有参数全部截取。相当于从第0位开始截取。
    // 一个参数代表截取从参数的位置往后的字符串。
    // 两个参数代表截取两个参数之间的字符串,包括第一个参数的位置,含头不含尾
    // 两个参数的时候,当第二个参数小于第一个参数,自动交换位置。
    // 如果是负数,当做0来处理。
    // var str = "abcdef"
    // console.log(str.substring()) //abcdef
    // console.log(str.substring(2)) //cdef
    // console.log(str.substring(-2)) //cdef,负数当做从头开始
    // console.log(str.substring(9)) //空,因为索引超过了str的length
    // console.log(str.substring(2, 5)) //cde,含头不含尾
    // console.log(str.substring(5, 2)) //cde,含头不含尾
    // console.log(str.substring(-2, 2)) //ab,当做0到2,含头不含尾
    // console.log(str.substring(-2, 9)) //abcdef,当做从0到最后

    // 8.substr(start, length); 用来截取字符串的内容,如果截取的长度超过字符串内容长度,则只截取有的部分,不会从头截取
    // //start:开始的索引,如果为负数,从后往前进行数,包括开始的索引。
    // //length:截取的长度
    // var str = "abcdef"
    // console.log(str.substr()) //abcdef
    // console.log(str.substr(2)) //cdef
    // console.log(str.substr(-2)) //ef
    // console.log(str.substr(8)) //空,开始位置超过长度
    // console.log(str.substr(2, -2)) //空,截取长度不可以为负数

    //9. toUpperCase()转换成大写  写法 字符串.toUpperCase
    // var str = "abcdef"
    // console.log(str.toUpperCase()) //ABCDEF

    // 10. toLowerCase()转换成小写
    // var str = "ABCDEF"
    // console.log(str.toLowerCase()) //abcdef


    // 共有:
    // 11.slice() 截取字符串的方法,如果为负数,从后往前进行截取,包括开始的索引。
    // var str = "abcdef"
    // var str1 = str.slice(1) //原数组不变,返回值是被截取的数值组成的数组
    // console.log(str, str1) //abcdef bcdef
    // var str1 = str.slice(1, 3) //含头不含尾
    // console.log(str, str1) //abcdef bc
    // var str1 = str.slice(-3) //负数从后往前数
    // console.log(str, str1) //abcdef def
    // var str1 = str.slice(-3, -6) //开头的索引大于结束的索引,不截取
    // console.log(str, str1) //abcdef

    // 12.indexOf和13.lastIndexOf():区别是如果第二个参数为负数,数组是从后往前找,字符串是当做0处理。
    // var str = "abcdcef"
    // console.log(str.indexOf("c")) //2
    // console.log(str.indexOf("c", 3)) //4
    // console.log(str.indexOf("c", -2)) //2,负数从头找,和数组不同,不会倒数

	// console.log(str.lastIndexOf("c")) //4
    // console.log(str.lastIndexOf("c", 3)) //2
    // console.log(str.lastIndexOf("c", -2)) //-1,找不到,因为相当于在开头往前找,不存在

    // 14.concat( ):和数组方法使用一致。
    // var str = "abc"
    // var str1 = str.concat("efg")
    // console.log(str, str1)//abc abcefg  原数组不变

	//**字符串扩展**
	// repeat(n)方法返回一个新字符串,表示将原字符串重复n次。
    // var str = 'hello';
    // console.log(str.repeat(10));//hellohellohellohellohellohellohellohellohellohello
    
    // includes():返回布尔值,表示是否找到了参数字符串。
    var str = 'javascript';
    console.log(str.includes('scr'));//true
    console.log(str.includes('v'));//true
    console.log(str.includes('vas'));//true
    console.log(str.includes('vaas')); //false

    var arr = ['zhangsan', 'lisi', 'wangwu'];//可以找数组里面是否有对应的字符串
    console.log(arr.indexOf('lisi')); //1
    console.log(arr.includes('lisi')); //true

    // startsWith():返回布尔值,表示参数字符串是否在源字符串的头部。
    var str = 'javascript';
    console.log(str.startsWith('ja'));//true
    console.log(str.startsWith('jav'));//true
    console.log(str.startsWith('javv')); //false

    // endsWith():返回布尔值,表示参数字符串是否在源字符串的尾部。
    var str = 'javascript';
    console.log(str.endsWith('ipt'));//true
    console.log(str.endsWith('t'));//true
    console.log(str.endsWith('tt')); //false

个人见解,仅供参考,概不负责QAQ

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaScript可以使用内置的JSON对象来解析JSON字符串。JSON对象有两个方法:JSON.parse()和JSON.stringify()。JSON.parse()方法将JSON字符串转换为JavaScript对象,而JSON.stringify()方法JavaScript对象转换为JSON字符串。例如: var jsonStr = '{"name":"John","age":30,"city":"New York"}'; var jsonObj = JSON.parse(jsonStr); console.log(jsonObj.name); //输出John 在这个例子中,我们首先定义了一个JSON字符串,然后使用JSON.parse()方法将其转换为JavaScript对象。最后,我们访问了对象的name属性并将其输出到控制台。 需要注意的是,JSON字符串必须符合JSON格式,否则解析会失败。例如,如果JSON字符串中有未加引号的属性名或单引号而不是双引号,解析将失败。 ### 回答2: JSON全称是JavaScript Object Notation,是一种轻巧的数据交换格式。JSON中的数据结构类似于JavaScript对象,因此JavaScript可以方便地解析JSON字符串。 在JavaScript中,可以使用eval()函数来解析JSON字符串。eval()函数将一个字符串当作JavaScript代码执行并返回结果。因此,我们可以使用eval()函数将JSON字符串转换为JavaScript对象,从而完成解析。 但是eval()函数存在一些安全问题,因为它会执行输入的任何JavaScript代码。如果JSON字符串来自不受信任的来源,那么可能包含恶意代码,会导致安全漏洞。因此,eval()函数不是解析JSON字符串的最佳方法。 现代浏览器提供了JSON.parse()方法解析JSON字符串。JSON.parse()可以将JSON字符串转换为JavaScript对象,而且对于不合法的JSON格式会抛出异常以及其他一些问题,例如,JSON字符串内部的单引号、指数表示法和特定值(如undefined)可能无法在JSON中表示,需要进行特殊处理。 JSON.parse(str, reviver)函数可以接收一个reviver参数,可以用来转换解析出来的结果。reviver是一个函数,它接收两个参数,一个是属性名,另一个是属性值。当JSON.parse()解析出属性值后,就会调用reviver函数,这样就可以在这个函数内部对这个属性进行处理。 在代码中,如果我们有一个JSON字符串,我们可以使用JSON.parse()来解析它。例如: var jsonString = '{"name": "John", "age": 30, "city": "New York"}'; var jsonObj = JSON.parse(jsonString); console.log(jsonObj.name); // 输出 "John" 解析后的jsonObj就是一个JavaScript对象,我们可以直接访问其中的属性。 总结来说,JavaScript可以使用eval()函数或JSON.parse()方法解析JSON字符串,但是安全考虑应该优先选择使用JSON.parse()方法。JSON.parse()方法还可以使用reviver参数来对解析出的结果进行转换和处理。 ### 回答3: 在JavaScript中,解析JSON字符串是常见的操作。JSON是JavaScript对象表示法的缩写,它是一种轻量级的数据交换格式。它提供了一种简单的方式来描述复杂的数据结构,包括数组和对象。 JavaScript内置了一个解析JSON字符串的函数`JSON.parse()`。此函数可以将JSON字符串转换为JavaScript对象,使开发者能够轻松地操作这些数据。 例如,如果我们有以下JSON字符串: ```javascript var jsonString = '{"name": "Tom", "age": 21, "gender": "male"}'; ``` 我们可以使用`JSON.parse()`来将其解析成一个对象: ```javascript var json = JSON.parse(jsonString); console.log(json.name); //输出 "Tom" console.log(json.age); //输出 21 console.log(json.gender); //输出 "male" ``` 除了从字符串解析JSON外,我们还可以使用`JSON.stringify()`函数将JavaScript对象转换为JSON字符串。例如,如果我们有以下JavaScript对象: ```javascript var obj = { name: "Tom", age: 21, gender: "male" }; ``` 我们可以使用`JSON.stringify()`将其转换为JSON字符串: ```javascript var jsonString = JSON.stringify(obj); console.log(jsonString); //输出 '{"name":"Tom","age":21,"gender":"male"}' ``` 在处理JSON字符串时,我们需要注意一些安全问题。首先,我们应该始终验证输入的JSON字符串是否有效。这可以通过尝试解析JSON字符串并检查是否发生了解析错误来实现。另外,我们还应该注意JSON字符串中的潜在安全漏洞,如JSON注入攻击。在通过用户输入的JSON字符串进行操作时,我们需要确保输入不包含恶意代码或攻击脚本。 总之,在JavaScript解析JSON字符串是非常重要的,它使得我们能够使用和交换复杂的数据结构。通过`JSON.parse()`和`JSON.stringify()`函数,我们可以轻松地将JSON数据转换为JavaScript对象或字符串,并进行操作和传输。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值