感觉你这个逻辑好奇怪! 为什么不是直接用 | 拆分成一个数组呢!?
先用最基本的substring方法处理一下吧:
<html><head>
<script language="javascript">
function Window_Load(){
var str = "abc|def|g"
var position = str.indexOf("|")
var ls = str.substring(0,position)
alert(ls) // 第一个 | 左边的字串: abc
var rs = str.substr(position + 1).replace("|","")
alert(rs) // 第一个 | 右边的字串: defg
}
</script>
</head>
<body onload="Window_Load()">
</body>
</html>
正常的拆分最好还是用split方法:
<html><head>
<script language="javascript">
function Window_Load(){
var str = "abc|def|g"
var data = str.split("|")
//左边的字串: abc
var ls = data.shift()
alert(ls)
//右边的字串: defg
var rs = data.join("")
alert(rs)
}
</script>
</head>
<body onload="Window_Load()">
</body>
</html>
可以用substring或者substr截取字符串。详解:substring 方法用于提取字符串中介于两个指定下标之间的字符。语法:stringObject.substring(start,end)start:必需。一个非负的整数,规定要提取的子串的第一个字符在 stringObject 中的位置。stop:可选。一个非负的整数,比要提取的子串的最后一个字符在 stringObject 中的位置多 1。如果省略该参数,那么返回的子串会一直到字符串的结尾。 返回值:一个新的字符串,该字符串值包含 stringObject 的一个子字符串,其内容是从 start 处到 stop-1 处的所有字符,其长度为 stop 减 start。注意:substring 方法返回的子串包括 start 处的字符,但不包括 end 处的字符。如果 start 与 end 相等,那么该方法返回的就是一个空串(即长度为 0 的字符串)。如果 start 比 end 大,那么该方法在提取子串之前会先交换这两个参数。如果 start 或 end 为负数,那么它将被替换为 0。substr 方法用于返回一个从指定位置开始的指定长度的子字符串。语法:stringObject.substr(start ,length)start:必需。所需的子字符串的起始位置。字符串中的第一个字符的索引为 0。length 可选。在返回的子字符串中应包括的字符个数。注意:如果start为负数,则start=str.length+start。如果 length 为 0 或负数,将返回一个空字符串。如果没有指定该参数,则子字符串将延续到stringObject的最后。var str = "hello world!"////控制台输出以空格分隔
console.log(str.trim().split(/\s+/))
console.log(str.trim().split(/\s+/).length)
str="12,255,3,5,6,6"//这是一字符串
var strs= new Array()//定义一数组
strs=str.split(",")//字符分割
for (i=0i<strs.length i++ )
{
document.write(strs[i]+" ")//分割后的字符输出
}