slice,substr,substring的区别

<!DOCTYPE html>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->
<html>
    <head>
        <title>TODO supply a title</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <script>
            var str="123456";
            console.log(str.slice(0));
            console.log(str.slice(0,4));
            console.log(str.slice(0,-1));
            console.log(str.slice(-1));
            console.log(str.slice(-5));
            
            //123456|1234|12345|6|23456
            
            console.log(str.substr(0));
            console.log(str.substr(0,4));
            console.log(str.substr(0,-1));
            console.log(str.substr(-1));
            console.log(str.substr(-5));
            
            //123456|1234|空字符串|6|23456
            
            console.log(str.substring(0));
            console.log(str.substring(0,4));
            console.log(str.substring(4,0))
            console.log(str.substring(0,-1));
            console.log(str.substring(-1));
            //123456|1234|1234|空字符串|123456
            /**
             * 总结三者的区别:
             * 1、substring(start,end)和slice(start,end)都表示提取从start下标开始(包括该下标上的字符)到end下标结束(不包括该下标上的字符)之间的内容,如果不包含end参数则表示提取从start到结尾的全部字符
             * 2、substring不支持负数参数(如果为负数则转换为0来处理),slice支持负数参数(如果参数为负数则表示从最右边算起,例1第一行中的0为-1,1为-2);substring如果start>end则互相交换,而slice则不支持交换
             * 3、substr其实是不是作为ECMAScript标准发布的,因此各种浏览器之间不是兼容的,但是既然提出来了还是讲一下substr(start,length)函数可以看出其实和上面两种函数的差别,即第二个参数代表的是截取的长度,不再是作为结尾下标来处理,所以该函数表示从开始下标start开始,向右截取length个长度的字符。按照w3c上来讲start是支持负数的,即表示从字符传的结尾开始计算,但是因为该函数并不是标准里的所以各浏览器实现不一,所以还是不建议用负数了。length为负数则不会截取任何字符,因为长度不可能为负的
             */
     
        </script>
    </head>
    <body>
        <div>TODO write content</div>
       
        
    </body>
</html>

 

posted @ 2017-06-23 12:04  Window2016  阅读(198)  评论(0编辑  收藏  举报