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