This article mainly introduces the common usage methods related to string in Javascript. Has very good reference value. Let’s take a look at it with the editor
I was just reading the Javascript Rhino book and saw the section on strings. I don’t have much exposure to this aspect in my daily work, so I thought I would sort it out in case I need it. .
One of the built-in functions of Javascript is string concatenation. If you use '+' to connect two numbers, it means adding the two numbers. But if used in a string, it means that the second character is added after the first character.
var num=1+2; console.log(num); var msg='hello'+'world'; console.log(msg);
For strings, in addition to the length attribute, there are many other useful attributes, such as:
var str='hello,world'; console.log(str.length); console.log(str.charAt(0)); //第一个字符 console.log(str.charAt(str.length-1)); // 最后一个字符 //substring(starti,endi), 截取 字符串 起始startistartii, 到endi结束,且含头不含尾,没有 // 如果第二个参数没有, 就默认截取到最后一个。 console.log(str.substring(1,4)); console.log(str.substring(1)); //用法同上,为负数时,就是倒数开始算,一个参数含义是倒数几个。 console.log(str.slice(1,4)); console.log(str.slice(-3)); //字符‘l'首次出现的位置 console.log(str.indexOf('l')); //字符‘l'最后一次出现的位置 console.log(str.lastIndexOf('l')); //在位置下标3之后,首次出现的位置 console.log(str.indexOf('l',3)); //用‘,'分割为字符串 console.log(str.split(',')); // 把str中的小写h换成大写H console.log(str.replace('h','H')); //讲字符串转化为大写 console.log(str.toUpperCase());
Tips: The string itself is fixed in JavaScript. The above methods will return a new string value and will not affect the value of str itself.
It is worth noting that in ES6 , adds many new methods to strings, such as:
var s = 'Hello world!'; // 返回布尔值,表示参数字符串是否在源字符串中的头部 console.log(s.startsWith('Hello')) // true //endsWith():返回布尔值,表示参数字符串是否在源字符串的尾部 console.log(s.endsWith('!')) // true // includes()返回布尔值,表示是否找到了参数字符串 console.log(s.includes('o')) // true
The above three methods all support the second parameter, which indicates the position to start search
var s = 'Hello world!'; console.log(s.startsWith('world', 6)) // true console.log(s.endsWith('Hello', 5))// true console.log(s.includes('Hello', 6)) // false
Tip: endsWith behaves differently than the other two methods. It targets the first n characters, while the other two methods target from the nth position until the end of the string.
The repeat method returns a new string, which means repeating the original string n times.
console.log('x'.repeat(3)) // "xxx" console.log('hello'.repeat(2)) // "hellohello" console.log('na'.repeat(0)) // ""
If the parameter is a decimal, it will be rounded.
console.log('na'.repeat(2.9)) // "nana" //如果repeat的参数是负数或者Infinity,会报错。 console.log('na'.repeat(Infinity)) // RangeError console.log('na'.repeat(-1)) // RangeError
However, if the parameter is a decimal between 0 and -1, it is equivalent to 0, because the rounding operation will be performed first. A decimal between 0 and -1 is equal to -0 after rounding, and repeat is regarded as 0.
console.log('na'.repeat(-0.9)) // "" //参数NaN等同于0 console.log('na'.repeat(NaN)) // " //如果repeat的参数是字符串,则会先转换成数字 console.log('na'.repeat('na')) // "" console.log('na'.repeat('3')) // "nanana"
ES2017 introduces the function of string completion length. If a string is not long enough, it will be completed at the head or tail. padStart() is used for head completion, padEnd() is used for tail completion
//padStart和padEnd一共接受两个参数,第一个参数用来指定字符串的最小长度,第二个参数是用来补全的字符串。 console.log('x'.padStart(5, 'ab')) // 'ababx' console.log('x'.padStart(4, 'ab')) // 'abax' console.log('x'.padEnd(5, 'ab')) // 'xabab' console.log('x'.padEnd(4, 'ab')) // 'xaba' //如果原字符串的长度,等于或大于指定的最小长度,则返回原字符串。 console.log('xxx'.padStart(2, 'ab')) // 'xxx' console.log('xxx'.padEnd(2, 'ab')) // 'xxx' //如果用来补全的字符串与原字符串,两者的长度之和超过了指定的最小长度,则会截去超出位数的补全字符串。 consoe.log('abc'.padStart(10, '0123456789')) // '0123456abc' //如果省略第二个参数,默认使用空格补全长度。 console.log('x'.padStart(4)) // ' x' console.log('x'.padEnd(4)) // 'x ' //padStart的常见用途是为数值补全指定位数。下面代码生成10位的数值字符串。 console.log('1'.padStart(10, '0') )// "0000000001" console.log('12'.padStart(10, '0')) // "0000000012" console.log('123456'.padStart(10, '0')) // "0000123456" //另一个用途是提示字符串格式。 console.log('12'.padStart(10, 'YYYY-MM-DD')) // "YYYY-MM-12" console.log('09-12'.padStart(10, 'YYYY-MM-DD'))// "YYYY-09-12"
The above is the detailed content of Summary of commonly used string usage methods in Javascript. For more information, please follow other related articles on the PHP Chinese website!

JavaScript core data types are consistent in browsers and Node.js, but are handled differently from the extra types. 1) The global object is window in the browser and global in Node.js. 2) Node.js' unique Buffer object, used to process binary data. 3) There are also differences in performance and time processing, and the code needs to be adjusted according to the environment.

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

The main difference between Python and JavaScript is the type system and application scenarios. 1. Python uses dynamic types, suitable for scientific computing and data analysis. 2. JavaScript adopts weak types and is widely used in front-end and full-stack development. The two have their own advantages in asynchronous programming and performance optimization, and should be decided according to project requirements when choosing.

Whether to choose Python or JavaScript depends on the project type: 1) Choose Python for data science and automation tasks; 2) Choose JavaScript for front-end and full-stack development. Python is favored for its powerful library in data processing and automation, while JavaScript is indispensable for its advantages in web interaction and full-stack development.

Python and JavaScript each have their own advantages, and the choice depends on project needs and personal preferences. 1. Python is easy to learn, with concise syntax, suitable for data science and back-end development, but has a slow execution speed. 2. JavaScript is everywhere in front-end development and has strong asynchronous programming capabilities. Node.js makes it suitable for full-stack development, but the syntax may be complex and error-prone.

JavaScriptisnotbuiltonCorC ;it'saninterpretedlanguagethatrunsonenginesoftenwritteninC .1)JavaScriptwasdesignedasalightweight,interpretedlanguageforwebbrowsers.2)EnginesevolvedfromsimpleinterpreterstoJITcompilers,typicallyinC ,improvingperformance.

JavaScript can be used for front-end and back-end development. The front-end enhances the user experience through DOM operations, and the back-end handles server tasks through Node.js. 1. Front-end example: Change the content of the web page text. 2. Backend example: Create a Node.js server.

Choosing Python or JavaScript should be based on career development, learning curve and ecosystem: 1) Career development: Python is suitable for data science and back-end development, while JavaScript is suitable for front-end and full-stack development. 2) Learning curve: Python syntax is concise and suitable for beginners; JavaScript syntax is flexible. 3) Ecosystem: Python has rich scientific computing libraries, and JavaScript has a powerful front-end framework.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

Atom editor mac version download
The most popular open source editor

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version
God-level code editing software (SublimeText3)
