ES6 - วิธีการสตริงใหม่
ต่อไปนี้เป็นรายการวิธีการพร้อมคำอธิบาย
ซีเนียร์ No | วิธีการและคำอธิบาย |
---|---|
1 | String.prototype.startsWith (searchString ตำแหน่ง = 0) ส่งคืนค่าจริงหากตัวรับเริ่มต้นด้วย searchString ตำแหน่งช่วยให้คุณระบุตำแหน่งที่จะตรวจสอบสตริงเริ่มต้น |
2 | String.prototype.endsWith (searchString, endPosition = searchString.length) ส่งคืนค่าจริงหากตัวรับเริ่มต้นด้วย searchString ตำแหน่งช่วยให้คุณระบุตำแหน่งที่จะตรวจสอบสตริงเริ่มต้น |
3 | String.prototype.includes (searchString ตำแหน่ง = 0) ส่งคืนจริงถ้าเครื่องรับมี searchString ตำแหน่งช่วยให้คุณระบุตำแหน่งที่สตริงที่จะค้นหาเริ่มต้น |
4 | String.prototype.repeat (นับ) ส่งกลับตัวรับเวลานับที่ต่อกัน |
แม่แบบตัวอักษร
Template literals เป็นตัวอักษรสตริงที่อนุญาตให้มีนิพจน์ฝังตัว Templatestringsใช้ back-ticks (``) แทนเครื่องหมายคำพูดเดี่ยวหรือคู่ สตริงแม่แบบสามารถเขียนเป็น -
var greeting = `Hello World!`;
การแก้ไขสตริงและตัวอักษรเทมเพลต
สตริงเทมเพลตสามารถใช้ตัวยึดตำแหน่งสำหรับการแทนที่สตริงโดยใช้ไวยากรณ์ $ {} ดังที่แสดง
Example 1
var name = "Brendan";
console.log('Hello, ${name}!');
ผลลัพธ์ต่อไปนี้จะแสดงเมื่อดำเนินการตามโค้ดด้านบนสำเร็จ
Hello, Brendan!
Example 2: Template literals and expressions
var a = 10;
var b = 10;
console.log(`The sum of ${a} and ${b} is ${a+b} `);
ผลลัพธ์ต่อไปนี้จะแสดงเมื่อดำเนินการตามโค้ดด้านบนสำเร็จ
The sum of 10 and 10 is 20
Example 3: Template literals and function expression
function fn() { return "Hello World"; }
console.log(`Message: ${fn()} !!`);
ผลลัพธ์ต่อไปนี้จะแสดงเมื่อดำเนินการตามโค้ดด้านบนสำเร็จ
Message: Hello World !!
สตริงหลายบรรทัดและตัวอักษรแม่แบบ
สตริงเทมเพลตสามารถมีได้หลายบรรทัด
Example
var multiLine = `
This is
a string
with multiple
lines`;
console.log(multiLine)
ผลลัพธ์ต่อไปนี้จะแสดงเมื่อดำเนินการตามโค้ดด้านบนสำเร็จ
This is
a string
with multiple
line
String.raw ()
ES6 มีฟังก์ชันแท็ก String.raw สำหรับสตริงดิบโดยที่แบ็กสแลชไม่มีความหมายพิเศษ String.rawช่วยให้เราสามารถเขียนแบ็กสแลชได้เหมือนกับที่เราทำในนิพจน์ทั่วไปตามตัวอักษร ลองพิจารณาตัวอย่างต่อไปนี้
var text =`Hello \n World`
console.log(text)
var raw_text = String.raw`Hello \n World `
console.log(raw_text)
ผลลัพธ์ต่อไปนี้จะแสดงเมื่อดำเนินการตามโค้ดด้านบนสำเร็จ
Hello
World
Hello \n World
เทมเพลตที่ติดแท็ก
ก tagเป็นฟังก์ชันที่สามารถตีความและประมวลผลเทมเพลตตามตัวอักษร แท็กปรากฏขึ้นด้านหน้าลิเทอรัลของเทมเพลต ไวยากรณ์แสดงอยู่ด้านล่าง
ไวยากรณ์
let output_fromTag = tagFunction `Template literal with ${variable1} , ${variable2}`
ไวยากรณ์การติดตั้งฟังก์ชันแท็กมีดังต่อไปนี้ -
function tagFunction(literals,...variable_values){
//process
return "some result"
}
ตัวอย่าง
ตัวอย่างต่อไปนี้กำหนดฟังก์ชันแท็ก myTagFn(). จะแสดงพารามิเตอร์ที่ส่งผ่านไป หลังจากแสดงผลจะกลับมาDone ไปยังผู้โทร
<script>
function myTagFn(literals,...values){
console.log("literal values are");
for(let c of literals){
console.log(c)
}
console.log("variable values are ");
for(let c of values){
console.log(c)
}
return "Done"
}
let company = `TutorialsPoint`
let company_location = `Mumbai`
let result = myTagFn `Hello this is ${company} from ${company_location}`
console.log(result)
</script>
ผลลัพธ์ของโค้ดด้านบนจะเป็นไปตามที่ระบุไว้ด้านล่าง -
//literal
literal values are
Hello this is
from
//values
variable values are
TutorialsPoint
Mumbai
Done
ตัวอย่าง
ด้านล่าง tag function ใช้เวลา template literal และแปลงเป็นตัวพิมพ์ใหญ่ตามที่แสดงด้านล่าง -
<script>
function convertToUpperTagFn(literals, ...values) {
let result = "";
for (let i = 0; i < literals.length; i++) {
result += literals[i];
if (i < values.length) {
result += values[i];
}
}
return result.toUpperCase();
}
let company = `TutorialsPoint`
let company_location = `Mumbai`
let result = convertToUpperTagFn `Hello this is ${company} from ${company_location}`
console.log(result)
</script>
ผลลัพธ์ของโค้ดด้านบนจะเป็นดังที่ระบุไว้ด้านล่าง -
HELLO THIS IS TUTORIALSPOINT FROM MUMBAI
String.fromCodePoint ()
สตริงคงที่fromCodePoint()วิธีการส่งคืนสตริงที่สร้างขึ้นโดยใช้ลำดับที่ระบุของจุดรหัสยูนิโคด ฟังก์ชันจะแสดง RangeError หากมีการส่งผ่านจุดรหัสที่ไม่ถูกต้อง
console.log(String.fromCodePoint(42))
console.log(String.fromCodePoint(65, 90))
ผลลัพธ์ต่อไปนี้จะแสดงเมื่อดำเนินการตามโค้ดด้านบนสำเร็จ
*
AZ