亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1953 | 回復(fù): 0
打印 上一主題 下一主題

用 JavaScript 操作字符串 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2016-01-28 15:10 |只看該作者 |倒序瀏覽
最新用 JavaScript 操作字符串
以下是三零網(wǎng)為大家整理的最新用 JavaScript 操作字符串的文章,希望大家能夠喜歡!
雖然 JavaScript 有很多用處,但是處理字符串是其中最流行的一個。下面讓我們深入地分析一下使用 JavaScript 操作字符串。在 JavaScript 中, String 是對象。 String 對象并不是以字符數(shù)組的方式存儲的,所以我們必須使用內(nèi)建函數(shù)來操縱它們的值。這些內(nèi)建函數(shù)提供了不同的方法來訪問字符串變量的內(nèi)容。下面我們詳細(xì)看一下這些函數(shù)。
包羅萬象
操作字符串的值是一般的開發(fā)人員必須面臨的家常便飯。操作字符串的具體方式有很多,比如說從一個字符串是提取出一部分內(nèi)容來,或者確定一個字符串是否包含一個特定的字符。下面的 JavaScript 函數(shù)為開發(fā)人員提供了他們所需要的所有功能:
?  concat() – 將兩個或多個字符的文本組合起來,返回一個新的字符串。
?  indexOf() – 返回字符串中一個子串第一處出現(xiàn)的索引。如果沒有匹配項,返回 -1 。
?  charAT() – 返回指定位置的字符。
?  lastIndexOf() – 返回字符串中一個子串最后一處出現(xiàn)的索引,如果沒有匹配項,返回 -1 。

  
?  match() – 檢查一個字符串是否匹配一個正則表達(dá)式。
?  substring() – 返回字符串的一個子串。傳入?yún)?shù)是起始位置和結(jié)束位置。
?  replace() – 用來查找匹配一個正則表達(dá)式的字符串,然后使用新字符串代替匹配的字符串。
?  search() – 執(zhí)行一個正則表達(dá)式匹配查找。如果查找成功,返回字符串中匹配的索引值。否則返回 -1 。
?  slice() – 提取字符串的一部分,并返回一個新字符串。
?  split() – 通過將字符串劃分成子串,將一個字符串做成一個字符串?dāng)?shù)組。
?  length() – 返回字符串的長度,所謂字符串的長度是指其包含的字符的個數(shù)。
?  toLowerCase() – 將整個字符串轉(zhuǎn)成小寫字母。
?  toUpperCase() – 將整個字符串轉(zhuǎn)成大寫字母。
注意: concat 、 match 、 replace 和 search 函數(shù)是在 JavaScript 1.2 中加入的。所有其它函數(shù)在 JavaScript 1.0 就已經(jīng)提供了。
下面讓我們看一下如何在 JavaScript 使用這些函數(shù)。下面的代碼是用到了前面提到的所有函數(shù):
function manipulateString(passedString1, passedString2) {
var concatString;
// The string passed to concat is added to the end of the first string
concatString = passedString1.concat(passedString2);
alert(concatString);
// The following if statement will be true since first word is Tony
if (concatString.charAt(3) == "y") {
alert("Character found!");
}
// The last position of the letter n is 10
alert("The last index of n is: " + concatString.lastIndexOf("n"));
// A regular expression is used to locate and replace the substring
var newString = concatString.replace(/Tony/gi,"General");
// The following yields Please salute General Patton
alert("Please salute " + newString);
// The match function returns an array containing all matches found
matchArray = concatString.match(/Tony/gi);
for (var i=0; i<matchArray.length;i++) {
alert("Match found: " + matchArray[i]);
}
// Determine if the regular expression is found, a –1 indicates no
if (newString.search(/Tony/) == -1) {
alert("String not found");
} else {
alert("String found.");
}
// Extract a portion of the string and store it in a new variable
var sliceString = newString.slice(newString.indexOf("l")+2,newString.length);
alert(sliceString);
// The split function creates a new array containing each value separated by a space
stringArray = concatString.split(" ");
for (var i=0; i<stringArray.length;i++) {
alert(stringArray[i];
}
alert(newString.toUpperCase());
alert(newString.toLowerCase());
}
下面是執(zhí)行上面的代碼得到的結(jié)果:
Tony Patton
Character Found!
The last index of n is: 10
Match found: Tony
Please salute General Patton
String not found
Patton
Tony
Patton
GENERAL PATTON
general patton
示例代碼把所有這些提到的函數(shù)都用到了。
特殊字符
除了這些函數(shù)之外,還有很多的特殊字符可以用來表示關(guān)鍵的效果。這些特殊字符包括:
?  t – 跳格鍵
?  b – 退格 / 刪除
?  r – 回車
?  n – 換行
?  f – 換頁
特殊字符最常見的用途就是格式化輸出。例如,你可能需要在輸出中插入一個換行來正確地顯示一個值。而且,在換行時也需要回車。在一些平臺上,“ n ”已經(jīng)足夠產(chǎn)生換行效果了,而在一些機器上要正確地顯示一個換行則需要“ rn ”。下面的例子顯示了在一個多行窗口上顯示的特殊字符:
var output = null;
output = "Special Characters";
output += "n";
output += "===============";
output += "n";
output += "\t - tab";
output += "n";
output += "\b - backspace/delete";
output += "n";
output += "\r - carriage return";
output += "n";
output += "\n - newline";
output += "n";
output += "\f - form feed";
output += "n";
alert(output);

前面的例子使用加號來連接字符串,而沒有使用 concat 函數(shù)。原因很簡單,對于 concat 函數(shù)來說,每一個操作都需要一個新的變量;反之,我們這里用的這種方法則簡單地擴展了原有的值,而不需要新的變量。而且,示例中使用換碼符來正確地顯示特殊字符。系統(tǒng)將一個反斜線當(dāng)作一個信號,認(rèn)為它后面會跟一個特殊字符,但是連著兩個反斜線則抵消這種操作。輸出中的每個字符都通過 newline 特殊字符被顯示在新的一行。
添加到工具箱中
特殊字符和函數(shù)可以與其它 JavaScript 技巧結(jié)合起來解決很多問題。其中一種情況是用來進(jìn)行 JavaScript 客戶端表單驗證,這篇文章中提出的方法可以簡單地用來實現(xiàn)表單驗證。
下面的代碼將在一個表單被提交時調(diào)用。要提交的表單包含三個域:名稱、地址和郵政編碼。為了實現(xiàn)起來比較簡單,我們只驗證每個域都不能為空,并且郵政編碼必須是數(shù)字。下面的 JavaScript 代碼完成這一功能:
function validation() {
var doc = document.forms[0];
var msg = "";
if (doc.Name.value == "") {
msg += "- Name is missingn";
}
if (doc.Address.value == "") {
msg += "- Address is missingn";
}
if (doc.ZipCode.value == "") {
msg += "- Zip code is missingn";
}
var zip = new String(doc.ZipCode.value);
if (zip.search(/^[0-9][0-9][0-9][0-9][0-9]$/)==-1) {
msg += "- Enter valid Zip code";
}
if (msg == "") {
doc.submit;
} else {
msg = "Please correct the following validation errors and re-submit:nn" + msg;
alert(msg);
}
}
在用戶提交表單時,這個函數(shù)就會被調(diào)用。對函數(shù)的調(diào)用是在一個 HTML 按鈕的 onSubmit 事件中實現(xiàn)的。
<input type="button" type="submit" value="submit" onClick="validation()">
驗證函數(shù)檢查每個域是否為空。如果發(fā)現(xiàn)了一個空值,那么就會在驗證消息變量 msg 后面添加一個出錯消息。此外,還使用了一個正則表達(dá)式來驗證郵政編碼域的格式。在這里,我們只接受五位數(shù)的美國地區(qū)郵政編碼。如果發(fā)現(xiàn)有任何錯誤(即 msg 變量不為空),那么程序就會顯示一個錯誤消息;否則的話,程序就會提交表單。
一門強大的語言
JavaScript 已經(jīng)發(fā)展成熟為一種功能完備的語言,能夠用來構(gòu)建強大的應(yīng)用程序。它是對具有非連接性天性的 Web 界面的一個完美的補充,能夠在不與 Web 服務(wù)器交互的情況下完成很多客戶端操作。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP