Heim > Web-Frontend > js-Tutorial > Hauptteil

Details zu praktischen JavaScript-String-Routinen

黄舟
Freigeben: 2017-03-03 14:58:33
Original
1118 Leute haben es durchsucht

JavaScript-Strings werden zum Speichern und Bearbeiten von Text verwendet. Daher ist sie immer dabei, wenn Sie JS-Code schreiben, wenn Sie die Eigenschaften von DOM-Objekten lesen oder festlegen, wenn Sie verschiedene Daten konvertieren und so weiter count; und ihre vielen APIs führen dazu, dass sich die Leute immer nur ungern daran erinnern. Da Sie sie häufig verwenden, können Sie sie auch durchstöbern, und das spiegelt übrigens auch den Wert der Existenz des Blogs wider Diese Zusammenfassung. 烂笔头

String-Interception

1. substring()

xString.substring(start,end)
Nach dem Login kopieren
substring() ist die am häufigsten verwendete String-Interception-Methode. Sie kann zwei Parameter empfangen (Parameter dürfen nicht negativ sein). ), die jeweils die abzufangende Start- und Endposition darstellen. Es wird eine neue Zeichenfolge zurückgegeben, deren Inhalt alle Zeichen von Anfang bis Ende-1 umfasst. Wenn der Endparameter (end) weggelassen wird, bedeutet dies, dass von der Startposition bis zum Ende abgefangen wird.

let str = 'www.jeffjade.com'
console.log(str.substring(0,3)) // www
console.log(str.substring(0))   //www.jeffjade.com
console.log(str.substring(-2))  //www.jeffjade.com (传负值则视为0)
Nach dem Login kopieren
2. Slice()

stringObject.slice(start, end)
Nach dem Login kopieren
Die Slice()-Methode ist der Substring()-Methode sehr ähnlich. Die beiden Parameter, die sie übergibt, entsprechen auch der Startposition und das Ende. Der Unterschied besteht darin, dass der Parameter in Slice() ein negativer Wert sein kann. Wenn der Parameter eine negative Zahl ist, gibt der Parameter die Position ab dem Ende der Zeichenfolge an. Das heißt, -1 bezieht sich auf das letzte Zeichen der Zeichenfolge.

let str = 'www.jeffjade.com'
console.log(str.slice(0, 3))    // www
console.log(str.slice(-3, -1))  // co
console.log(str.slice(1, -1))   // www.jeffjade.co
console.log(str.slice(2, 1))    // '' (返回空字符串,start须小于end)
console.log(str.slice(-3, 0))   // '' (返回空字符串,start须小于end)
Nach dem Login kopieren
3. substr()

stringObject.substr(start,length)
Nach dem Login kopieren
Die substr()-Methode kann die angegebene Anzahl von Zeichen beginnend mit dem Startindex in der Zeichenfolge extrahieren. Der Rückgabewert ist eine Zeichenfolge mit Längenzeichen beginnend am Anfang von stringObject (einschließlich des Zeichens, auf das start zeigt). Wenn die Länge nicht angegeben ist, enthält die zurückgegebene Zeichenfolge Zeichen vom Anfang bis zum Ende von stringObject. Wenn start eine negative Zahl ist, bedeutet dies außerdem, dass vom Ende der Zeichenfolge aus gezählt wird.

let str = 'www.jeffjade.com'
console.log(webStr.substr(1, 3))   // ww.
console.log(webStr.substr(0))      // www.jeffjade.com
console.log(webStr.substr(-3, 3))  // com
console.log(webStr.substr(-1, 5))  // m  (目标长度较大的话,以实际截取的长度为准)
Nach dem Login kopieren
4. split()

str.split([separator][, limit])
Nach dem Login kopieren
  • Trennzeichen gibt das Zeichen (die Zeichenfolge) an, das zum Teilen der Zeichenfolge verwendet wird. Trennzeichen kann eine Zeichenfolge oder ein regulärer Ausdruck sein. Wenn das Trennzeichen weggelassen wird, wird ein Array der gesamten Zeichenfolge zurückgegeben. Wenn es sich bei „separator“ um eine leere Zeichenfolge handelt, gibt str ein Array aller Zeichen in der ursprünglichen Zeichenfolge zurück.

  • limit Eine Ganzzahl, die die Anzahl der zurückgegebenen geteilten Fragmente begrenzt. Die Split-Methode teilt weiterhin jedes übereinstimmende Trennzeichen auf, aber das zurückgegebene Array fängt nur die maximale Anzahl an Elementen ab.

let str = 'www.jeffjade.com'
str.split('.')      // ["www", "jeffjade", "com"]
str.split('.', 1)   // ["www"]
str.split('.').join('') // wwwjeffjadecom
Nach dem Login kopieren
Apropos, diese Funktion ist wirklich einfach zu verwenden. Oftmals hängen die Anforderungen zum Abfangen von Charakteren von einem bestimmten Charakter ab, und die oben genannten drei Funktionen müssen alle seine Position kennen . Natürlich können wir

und andere Methoden verwenden, um es zu erhalten. Dies ist natürlich sehr umständlich, aber die Verwendung von indexOf macht es einfacher. split

Suchklassenmethode

1. indexOf() & Includes()

stringObject.indexOf(searchValue,fromIndex)
Nach dem Login kopieren
indexOf() wird verwendet, um das erste Vorkommen eines angegebenen Zeichenfolgenwerts in a abzurufen String-Position. Es kann zwei Parameter empfangen: searchValue stellt die zu durchsuchende Teilzeichenfolge dar und fromIndex stellt die Startposition der Suche dar. Wenn dieser Parameter weggelassen wird, wird die Suche ab der Startposition durchgeführt.

let str = 'www.jeffjade.com'
console.log(str.indexOf('.'))     // 3
console.log(str.indexOf('.', 1))  // 3
console.log(str.indexOf('.', 5))  // 12
console.log(str.indexOf('.', 12)) // -1
Nach dem Login kopieren
Obwohl

verwendet wird, um die Position abzurufen, an der der angegebene Zeichenfolgenwert zum ersten Mal in der Zeichenfolge erscheint, wird es häufig verwendet, um zu bestimmen, ob die angegebene Zeichenfolge in der Zeichenfolge vorhanden ist sieht so aus: indexOf()

if (str.indexOf('yoursPecifiedStr') !== -1) {
    // do something
}
Nach dem Login kopieren
Sie müssen wissen, dass in einem solchen Szenario die include()-Methode in der ES6-Sprache viel eleganter ist, um zu bestimmen, ob eine Zeichenfolge enthalten ist Wenn es sich in einer anderen Zeichenfolge befindet, wird „true“ zurückgegeben, andernfalls wird „false“ zurückgegeben.

str.includes(searchString[, position])
Nach dem Login kopieren

searchString Der zu durchsuchende Teilstring. Position ist optional. Die Indexposition der aktuellen Zeichenfolge zum Starten der Suche nach Teilzeichenfolgen ist standardmäßig 0. Es ist zu beachten, dass bei include() die Groß-/Kleinschreibung beachtet wird.

'Blue Whale'.includes('blue'); // returns false
'乔峰乔布斯乔帮主'.includes('乔布斯'); // returns true
if (str.includes('yoursPecifiedStr')) {
    // do something(这样写是不是更为人性化?Yeah,这是一个更趋向人性化的时代嘛)
}
Nach dem Login kopieren
2. lastIndexOf()

stringObject.lastIndexOf(searchValue,fromIndex)
Nach dem Login kopieren
lastIndexOf() ähnelt der Syntax von indexOf(). Die Suchreihenfolge lautet von hinten nach vorne.

let str = 'www.jeffjade.com'
console.log(str.lastIndexOf('.'))     // 12
console.log(str.lastIndexOf('.', 1))  // -1
console.log(str.lastIndexOf('.', 5))  // 3
console.log(str.lastIndexOf('.', 12)) // 12
Nach dem Login kopieren
search()

stringObject.search(substr)
stringObject.search(regexp)
Nach dem Login kopieren
Die Methode search() wird verwendet, um einen angegebenen Teilstring in einem String abzurufen oder um einen Teilstring abzurufen, der einem regulären Ausdruck entspricht. Es gibt die Startposition des ersten passenden Teilstrings zurück oder -1, wenn es keine Übereinstimmung gibt.

let str = 'www.jeffjade.com'
console.log(str.search('w'))    // 0
console.log(str.search(/j/g))   // 4
console.log(str.search(/\./g))  // 3
Nach dem Login kopieren
match()-Methode

stringObject.match(substr)
stringObject.match(regexp)
Nach dem Login kopieren
Die match()-Methode kann einen angegebenen Wert innerhalb einer Zeichenfolge abrufen oder eine Übereinstimmung für einen oder mehrere reguläre Ausdrücke finden.

Wenn der übergebene Parameter ein Teilstring oder ein regulärer Ausdruck ist, der keinen globalen Abgleich durchführt, führt die Methode match() einen Abgleich von Anfang an durch. Wenn kein Ergebnis übereinstimmt, wird null zurückgegeben. Andernfalls wird ein Array zurückgegeben. Das 0. Element des Arrays speichert außerdem zwei Objektattribute, index und input, die jeweils den Startzeichenindex des passenden Textes und das stringObject darstellen. Referenz (d. h. Originalzeichenfolge).

let str = '#1a2b3c4d5e#';
console.log(str.match('A'));    //返回null
console.log(str.match('b'));    //返回["b", index: 4, input: "#1a2b3c4d5e#"]
console.log(str.match(/b/));    //返回["b", index: 4, input: "#1a2b3c4d5e#"]
Nach dem Login kopieren
Wenn der Parameter in einem regulären Ausdruck mit globaler Übereinstimmung übergeben wird, dann wird match() vom Anfang bis zum Ende mehrmals übereinstimmen. Wenn kein Ergebnis gefunden wird, wird null zurückgegeben. Andernfalls wird ein Array zurückgegeben, das alle Teilzeichenfolgen speichert, die die Anforderungen erfüllen, und über keine Index- und Eingabeattribute verfügt.

let str = '#1a2b3c4d5e#'
console.log(str.match(/h/g))     //返回null
console.log(str.match(/\d/g))    //返回["1", "2", "3", "4", "5"]
Nach dem Login kopieren

其他方法

replace()方法

stringObject.replace(regexp/substr,replacement)
Nach dem Login kopieren

replace()方法用来进行字符串替换操作,它可以接收两个参数,前者为被替换的子字符串(可以是正则),后者为用来替换的文本。

如果第一个参数传入的是子字符串或是没有进行全局匹配的正则表达式,那么replace()方法将只进行一次替换(即替换最前面的),返回经过一次替换后的结果字符串。

let str = 'www.jeffjade.com'
console.log(str.replace('w', 'W'))   // Www.jeffjade.com
console.log(str.replace(/w/, 'W'))   // Www.jeffjade.com
Nach dem Login kopieren

如果第一个参数传入的全局匹配的正则表达式,那么replace()将会对符合条件的子字符串进行多次替换,最后返回经过多次替换的结果字符串。

let str = 'www.jeffjade.com'
console.log(str.replace(/w/g, 'W'))   // WWW.jeffjade.com
Nach dem Login kopieren

toLowerCase() & toUpperCase()

stringObject.toLowerCase()
stringObject.toUpperCase()
Nach dem Login kopieren

toLowerCase()方法可以把字符串中的大写字母转换为小写,toUpperCase()方法可以把字符串中的小写字母转换为大写。

let str = 'www.jeffjade.com'
console.log(str.toLowerCase())   // www.jeffjade.com
console.log(str.toUpperCase())   // WWW.JEFFJADE.COM
Nach dem Login kopieren

模板字符串

这个也是 ES6 才引入进来的新语法,来解决传统输出String模板的蹩脚问题;其功能之强大,设计之贴心,着实令人得到极大满足感,好如久旱逢甘霖一般的舒畅。更何况,在当今 MVVM 前端框架大行其道的时代,使用 ES6 语法也是不用自己个儿去操心兼容性问题,对于塑造 Dom Template 更是如虎添翼,令人爱不释手。

对于她的使用,阮一峰在ECMAScript 6 入门有过详细的描述以及示例,在此就不赘述。只需要明白我们可以像这样去操作了,试问爽否?

function ncieFunc() {
  return "四海无人对夕阳";
}
var niceMan = "陈寅恪";
var jadeTalk = `一生负气成今日 \n ${ncieFunc()} ,
语出 ${niceMan} 的《忆故居》。
`
console.log(jadeTalk)
Nach dem Login kopieren

运行之,Chrome Console 输出结果如下:

一生负气成今日
四海无人对夕阳 ,
语出 陈寅恪 的《忆故居》。

组合其法

细看 JavaScript 提供的String Api,还是有蛮多的,也有些许废弃的,也有将在未来版本会出来的;这其中不乏很多也挺有用的,譬如: charAt(x)、charCodeAt(x)、concat(v1, v2,…)、fromCharCode(c1, c2,…) 等等,还有 ES6 对字符串的扩展,比如 字符串的遍历器接口,repeat() 等等,这可以参见 ES6-string,这里就不多赘述。

在实际代码生产中,很多时候需要用这些提供的基本方法,来打出一套组合拳,以解决其需求所需。很显然又可以借助 prototype 属性,将自造的各路拳法,其归置于 String 对象,然后天亮啦。这一步就看个人喜好了,这里抛出一二段,以引大玉。

字符串反转

String.prototype.reverse = function () {
	return this.split('').reverse().join('')
}
Nach dem Login kopieren

去除空白行

String.prototype.removeBlankLines = function () {
	return this.replace(/(\n[\s\t]*\r*\n)/g, '\n').replace(/^[\n\r\n\t]*|[\n\r\n\t]*$/g, '')
}
Nach dem Login kopieren

String转化为数组

1, 转化为一维数组

场景是根据某子字符串转化,直接就用 split 就好;如果转换规则不统一,那么请自求多福吧。

let Str = '陈寅恪,鲁迅,钱钟书,胡适,王国维,梁启超,吴宓,季羡林'
let hallAllOfFameArr = Str.split(',')
console.log(hallAllOfFameArr)
// ["陈寅恪", "鲁迅", "钱钟书", "胡适", "王国维", "梁启超", "吴宓", "季羡林"]
Nach dem Login kopieren

2, 转化为二维数组

String.prototype.removeBlankLines = function () {
	return this.replace(/(\n[\s\t]*\r*\n)/g, '\n').replace(/^[\n\r\n\t]*|[\n\r\n\t]*$/g, '')
}
String.prototype.strTo2dArr = function(firstSplit, secondSplit){
	var contentStr = this.removeBlankLines(),
		contentStrArr = contentStr.split(firstSplit),
		resultArr = contentStrArr.map((element) => {
            return element.split(secondSplit)
        })
	return resultArr
}
var str = `
渺渺钟声出远方,依依林影万鸦藏。
一生负气成今日,四海无人对夕阳。
破碎山河迎胜利,残馀岁月送凄凉。
松门松菊何年梦,且认他乡作故乡。
`
console.log(str.strTo2dArr('\n', ','))
Nach dem Login kopieren

运行之,输出结果如下:

[ [ ‘渺渺钟声出远方’, ‘依依林影万鸦藏。’ ],
[ ‘一生负气成今日’, ‘四海无人对夕阳。’ ],
[ ‘破碎山河迎胜利’, ‘残馀岁月送凄凉。’ ],
[ ‘松门松菊何年梦’, ‘且认他乡作故乡。’ ] ]

抗战时期,陈寅恪先生在给傅斯年的信中,说了这样一段话:“弟之生性,非得安眠饱食,不能作文,非是既富且乐,不能作诗,平生偶有安眠饱食之时,故偶可为文,而一生从无既富且乐之日,故总做不好诗。” 虽是以调侃的以言说,恐也是寄之感慨的悟道之语。自由独立的经济生活,是自由思想与独立人格的坚强后盾与实际保障。写博这事儿,也是一样,整日疲于需求之成改,熬时碌碌,生为糊口;偶有的闲时气力,哪儿是能经得起折腾的?唯是在垒码的间隙,略做记录,积而成篇。而这番为得的糊口的奋争,也是希望将来的某天——能有既富且乐之时,谈那些想谈的,做那些想做的事,如此而已。

 以上就是JavaScript 字符串实用常操纪要详情的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!