`
gift5168xf
  • 浏览: 28982 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Javascript对字符串的处理

阅读更多

一、声明字符串:
varnormal_monkey="Iamamonkey!<br>";
document.writeln("Normalmonkey"+normal_monkey);

varbold_monkey=normal_monkey.bold();
document.writeln("Boldmonkey"+bold_monkey);

这里的声明:varbold_monkey=normal_monkey.bold();
和下面对声明是等同的:
varbold_monkey="<b>"+normal_monkey+"</b>";

1 个版本的声明看起来要简明得多。这里用到了字符串对象中
bold 对象,其他的字符串对象还有indexOf,charAt,
substring,
以及split, 这些方法可以深入字符串的组成结构。
首先我们研究一下indexOf

2indexOf
indexOf
用于发现一系列的字符在一个字符串中等位置并告诉你子字符串的起始位置。如

果一个字符串中部包含该子字符串则indexOf 返回returns"-1."
例子:
varthe_word="monkey";
//
让我们从单词"monkey" 开始。
varlocation_of_m=the_word.indexOf("m");
//location_of_m(
字母m 的位置) 将为0 ,因为字母m 位于该字符串的起始位置。
varlocation_of_o=the_word.indexOf("o");
//location_of_o(
字母o 的位置) 将为1
varlocation_of_key=the_word.indexOf("key");
//location_of_key(key
的位置) 将为3 因为子字符串“key” 以字母k 开始,而k

在单词monkey 中的位置是3
varlocation_of_y=the_word.indexOf("y");
//location_of_y)
字母y 的位置)5
varcheeky=the_word.indexOf("q");
//cheeky
值是-1 ,因为在单词“monkey” 中没有字母q

indexOf 更实用之处:
varthe_email=prompt("What’syouremailaddress?","");
varthe_at_is_at=the_email.indexOf("@");
if(the_at_is_at==-1)
{
alert("Youloser,emailaddressesmust
have@signsinthem.");
}

这段代码询问用户的电子邮件地址,如果用户输入的电子邮件地址中不包含字符 则 提

示用户"@你输入的电子邮件地址无效,电子邮件的地址必须包含字符@ 。"

3charAt
chatAt
方法用于发现一个字符串中某个特定位置的字符。
这里是一个例子:
varthe_word="monkey";
varthe_first_letter=the_word.charAt(0);
varthe_second_letter=the_word.charAt(1);
varthe_last_letter=the_word.charAt(the_word.length-1);

the_first_letter(1 个字符)"m"
the_second_letter(
2 个字符)"o"
the_last_letter(
最后一个字符)"y"

注意利用字符串的length( 长度) 属性你可以发现在包含多少个字符。在本例中,

the_word"monkey" ,所以the_word.length6 。不要忘记在一个字符串中第1 个字符的

位置是0 ,所以最后一个字符的位置就是length-1 。所以在最后一行中用了

the_word.length-1>>

4 、子字符串(substring
子字符串(substring )和charAt 有些象,不同之处在于它能够从一个单词中抓取整个的

子字符串,而不只是字母,这里是其格式:

varthe_substring=the_string.substring(from,to);

"From" 指的是子字符串中第1个字母的位置,"to" 有点奇特,它是该子字符串中比最后

一个位置大1的位置.使用这种神奇的方法你可以标记子字符串的起始和结束位置,用

"to" 的位置减去"from" 的位置就会得出该子字符串的长度:

varthe_string="monkey";
varclergy=the_string.substring(0,4);
vartool=the_string.substring(3,6);

运行该段代码后变量clergy 的值为"monk"; 变量tool 的值为"key"

子字符串常和indexOf 一起使用,将字符串分成若干块.例如,
你可以从一个给定的URL 中抽取出其域名:

varthe_url=prompt("What’stheURL?","");
varlead_slashes=the_url.indexOf("//");
vardomain_start=lead_slashes+2;
varwithout_resource=the_url.substring(domain_start,the_url.length);
varnext_slash=without_resource.indexOf("/");
vardomain=without_resource.substring(0,next_slash);

这段代码的意思是:如果你输入
"http://www.webmonkey.com/javascript/index.html" ;
,则域名就是

"www.webmonkey.com" .如果这个方法对你来说有些麻烦,我将向你介绍如何使用split

方法简化其执行过程.但是首先我们作一些分析.

基本的技巧是将第1个斜杠和第2个斜杠之间的内容分离出来:
varthe_url=prompt("What’stheURL?","");
//
这行代码向用户询问一个URL .假设用户输入了
"http://www.webmonkey.com/javascript/index.html." ;
varlead_slashes=the_url.indexOf("//");
这行代码确定第一个双斜杠的位置.在本例中lead_slashes 的值是5,因为双斜杠的位

置从5开始.

你可能会想,通常的URL 都是以http:// 开始,所以双斜杠的位置肯定是在5开始,为什

么还要加入indexOf 这一段多余的代码呢?但是问题的关键在于你不知道用户在填入URL

时是否一定填入http: ,他们也许会不小心多键入了一个空格,也许他们所键入的URL

一个加密服务器上,其URL"https://www.whatever.com/" ; .在编程你必须预料到种种

可能发生的问题.所以我们必须用indexOf 方法确定双斜杠的确切的起始位置.

vardomain_start=lead_slashes+2;

这行代码用于计算该域名的第1个字母的起始位置.由于这里有一个双斜杠,所以域名

第1个字母的起始位置应该在双斜杠所在位置加2的位置.

varwithout_resource=the_url.substring(domain_start,the_string.length);

这段代码将域名起始位置往后的所有字符都提取出来.所以执行完这行代码后

without_resource"www.webmonkey.com/javascript/index.html."

varnext_slash=without_resource.indexOf("/");

这行代码计算出该字符串中下一个斜杠的位置,而从该字符串起始位置到这个斜杠之间

的内容就是域名.在本例中下一个斜杠的位置是17

vardomain=without_resource.substring(0,next_slash);

最后一步是提取出该字符串起始位置到下一个斜杠之间的所有内容.在本例中使得域名

等同于"www.webmonkey.com"

这样做确实很麻烦,利用split 方法则可以使该过程容易很多.>>

5 、分割方法(splittingmethod)
你可以使用split 方法用限位器来分割一系列的名称,然后将其
放在一个数组中.例如:

varmy_friends="trixie,moxie,sven,guido,hermes";

varfriend_array=my_friends.split(",");

for(loop=0;loop<friend_array.length;loop++)
{document.writeln(friend_array[loop]+"ismyfriend.<br>");}

这段代码将字符串my_friends 分割成包含5个元素的数组.JavaScript 可以为你自动建

立一个数组,所以你无需使用newArray()

将字符串分割成数组之后,我们使用了循环语句写出每一个名称.我们可以利用split

法简化前面所讲到的域名提取:

varthe_url=prompt("What’stheURL?","");
varfirst_split=the_url.split("//");
varwithout_resource=first_split[1];
varsecond_split=without_resource.split("/");
vardomain=second_split[0];

这段代码简化了很多而且也更容易理解.我们来分析一些这段代码:

varthe_url=prompt("What’stheURL?","");

提示用户输入一个URL ,假设用户输入
"http://www.webmonkey.com/javascript/index.html" ;

varfirst_split=the_url.split("//");
将用户输入的字符串分割成两块:first_split[0]"http:"first_split[1]

"www.webmonkey.com/javascript/index.html."
varwithout_resource=first_split[1];
//
提取出数组中的第2个元素,所以现在without_resource

"www.webmonkey.com/javascript/index.html."
varsecond_split=without_resource.split("/");
without_resource 分割成3块:www.webmonkey.com,javascript,index.html .现

在你可以看到split 的用途了吧?

vardomain=second_split[0];

现在我们提取出新数组中的第1个元素就可得出域名.

 

分享到:
评论

相关推荐

    Javascript中字符串相关常用的使用方法总结

    随着ECMAScript标准的不断发展,ES6及之后版本引入了许多新的字符串处理方法,进一步增强了JavaScript字符串操作的能力: 1. **检查字符串开头或结尾** - `startsWith(searchString[, position])` 和 `endsWith...

    头歌教学实践平台 Web前端开发基础 JavaScript学习手册九:字符串

    总结,JavaScript中的字符串是处理文本数据的基本工具。理解和掌握字符串的特性及操作方法,对于Web前端开发者来说至关重要。通过熟练运用这些知识点,开发者能够更高效地处理和展示网页上的文本信息。在实际项目中...

    javascript字符串操作

    ### JavaScript字符串操作详解 在JavaScript中,字符串是用于表示文本数据的一种基本数据类型。字符串可以包含单个字符或多个字符组合成的文本序列。本文将详细介绍JavaScript中的字符串操作方法,帮助开发者更好地...

    work2_分割字符串_字符串处理_

    字符串处理不仅是C语言的基本操作,也是其他编程语言(如Python、Java、JavaScript等)的核心部分。在Python中,可以使用内置的 `split()` 方法进行字符串分割,而在JavaScript中,可以使用 `split()` 函数或者正则...

    常用字符串处理整理.rar

    接下来,Jscript.cs可能涉及到JavaScript端的字符串处理,JavaScript在客户端处理字符串时有其独特的方式: 1. JavaScript的字符串拼接:在JavaScript中,"+"运算符可以用于字符串连接。 2. 字符串格式化:虽然...

    javascript字符串排序

    标题"javascript字符串排序"提示我们关注的重点是如何在JS环境中有效地对字符串进行排序。描述中提到的方法比默认的`sort()`方法效率更高,速度更快,这通常涉及到自定义排序函数的使用。 默认情况下,JavaScript的...

    常用字符串处理函数-求子字符串,字符串分割,编码转换.

    在现代编程语言如JavaScript中,字符串处理是日常开发中极为常见的任务之一。本文将深入探讨几个常用的字符串处理函数,包括如何求取子字符串、进行字符串分割以及执行编码转换。这些功能在网页开发、数据处理和文本...

    工具类_字符串处理

    在IT行业中,字符串处理是日常开发中的重要环节,无论是在数据解析、日志记录还是用户交互等场景,都离不开对字符串的操作。本篇主要聚焦于一个名为“工具类_字符串处理”的主题,它通常指的是一个包含多种字符串...

    JavaScript中的字符串操作 .txt

    字符串处理作为JavaScript编程中一个重要的组成部分,在实际应用中占据着举足轻重的地位。本文将深入探讨JavaScript中字符串操作的相关知识点,包括字符串的基本概念、常见操作方法及其应用场景。 #### 字符串的...

    js对字符串的处理

    主要介绍js对字符串处理的集中方法,不同的方法截取的位数不同

    JavaScript判断一个字符串是否包含指定子字符串的方法

    JavaScript是一种广泛使用的前端脚本语言,它为我们提供了丰富的API,能够操作DOM、处理事件、操作字符串等。在处理字符串时,判断一个...希望通过本文的介绍和示例,能够帮助到进行JavaScript字符串操作的开发者们。

    javaScript中的字符串操作

    在JavaScript编程中,字符串处理是一项非常基础且重要的技能。无论是用户输入的验证、DOM元素属性的读取与修改、还是Cookie的操作等场景,都离不开字符串的使用。JavaScript的核心部分提供了一系列属性和方法来帮助...

    javascript字符串处理函数汇总.pdf

    以下是对标题和描述中提及的JavaScript字符串处理函数的详细说明: 1. **concat()**:这个函数用于连接两个或多个字符串,创建一个新的字符串,而不会改变原始字符串。例如: ```javascript var str1 = "Hello "; ...

    javascript将字符串中的多个空格替换为一个空格的正则实例.docx

    通过以上介绍,我们可以看到,在JavaScript中处理字符串是非常灵活且强大的。利用正则表达式结合内置方法,我们可以轻松地解决诸如去除字符串中多余空格之类的问题。这对于提高代码的健壮性和用户体验都有很大的帮助...

    JavaScript截取中文字符串

    在进行文本处理时,我们经常需要对字符串进行截取操作。特别是在处理包含多种字符集(如英文与中文)的字符串时,考虑到不同字符编码长度的差异性,简单地按照字符数量进行截取可能会导致显示效果不佳或出现乱码等...

    theredoc让多行JavaScript字符串看起来排版更好

    在JavaScript编程中,我们经常需要处理多行字符串,特别是在创建模板、日志或者代码注释时。然而,JavaScript原生不支持多行字符串,我们通常使用反斜杠(\)来连接多行,但这会导致代码可读性降低,排版混乱。为了...

    ES6--javascript判断一个字符串是否存在另一个字符串中

    ES6(ECMAScript 2015)作为 JavaScript 的一个重要版本更新,引入了许多新特性,使得字符串处理变得更加简单、直观。本文将详细介绍 ES6 中用于判断字符串是否存在的三种主要方法:`includes()`、`startsWith()` 和...

Global site tag (gtag.js) - Google Analytics