字符串:截取表單網址裏的信息變成對象
阿新 • • 發佈:2018-12-12
就是 字符 bsp fun 判斷 title 信息 amp .com
字符串的方法
1.str.indexOf("?")返回?這個字符串的位置,也就是第幾位
2.str.slice(num)截取從num開始到結束的字符串,
str.slice(num1,num2)截取從num1開始到num2的字符串,
3.str.split("&")把字符串裏有&截斷。
首先我要獲取?後面的的字符串,我通過indexOf知道了?的位置
然後我把?之後的字符串截取出來了
然後用split函數去掉&然後把去掉&之後的字符串保存在數組裏,長度為3的一維數組
然後利用for循環和split把一維數組變成沒有=的二維數組
然後把二維數組賦值給對象
我還判斷值是否為數字,是數字就把類型轉變成number
附上整段代碼:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> <script type="text/javascript"> var str = "http://www.baidu.com?name=jack&age=30&sex=0" functionfun(str){ var num = str.indexOf("?"); var str1 = str.slice(num+1); var str2 = str1.split("&"); for (var j = 0;j<str2.length;j++) { str2[j]=str2[j].split("="); } var obj = {};for (var i = 0;i<str2.length;i++) { if (!isNaN(str2[i][1])) {//判斷值是否是數字,如果是數字就轉換成number類型 str2[i][1] = Number(str2[i][1]); }else{ str2[i][1]=str2[i][1]; } obj[str2[i][0]]=str2[i][1];//對象的賦值,和數組一樣,只是對象的索引不是數字,而是字符串 } // console.log(obj); return obj;//返回對象 } console.log(fun(str)); </script> </body> </html>
效果圖如下:
字符串:截取表單網址裏的信息變成對象