Aurelia - ตัวแปลง
หากคุณต้องการแปลงค่าบางอย่างในแอป Aurelia คุณสามารถใช้ไฟล์ converters แทนที่จะแปลงค่าเป็นรูปแบบที่ต้องการด้วยตนเอง
แปลงวันที่
เมื่อเราต้องการแปลงค่าวันที่เริ่มต้นเป็นรูปแบบเฉพาะบางอย่างเราสามารถใช้ momentJSห้องสมุด. นี่คือห้องสมุดขนาดเล็กที่ใช้สำหรับจัดการวันที่
C:\Users\username\Desktop\aureliaApp>jspm install moment
มาสร้างไฟล์ใหม่ converters.js. เราจะใช้ไฟล์นี้เพื่อเพิ่มรหัสเฉพาะของตัวแปลง ใช้คำสั่งต่อไปนี้หรือสร้างไฟล์ด้วยตนเอง
C:\Users\username\Desktop\aureliaApp>touch converters.js
converter.js
ภายในไฟล์นี้เราจะนำเข้า moment ห้องสมุดและชุด DateFormatValueConverterเพื่อส่งคืนเฉพาะค่าเดือนวันและปีโดยไม่มีข้อมูลเพิ่มเติม สิ่งสำคัญที่ควรทราบคือ Aurelia สามารถจดจำคลาสใดก็ได้ที่ลงท้ายด้วยValueConverter. นี่คือสาเหตุที่ชื่อชั้นของเราคือDateFormatValueConverter. คลาสนี้จะได้รับการลงทะเบียนเป็นdateFormat และเราสามารถใช้มันในภายหลังได้
converters.js
import moment from 'moment';
export class DateFormatValueConverter {
toView(value) {
return moment(value).format('M/D/YYYY');
}
}
ใน app.jsเราจะใช้วันที่ปัจจุบัน นี่จะเป็นโมเดลมุมมองของเรา
app.js
export class App {
constructor() {
this.currentDate = new Date();
}
}
เราคุยกันแล้ว require ใน custom-elementsบท. สัญลักษณ์ท่อ | ใช้เพื่อใช้ตัวแปลง เรากำลังใช้dateFormat เนื่องจากนี่คือวิธีการลงทะเบียน Aurelia DateFormatValueConverter.
app.html
<template>
<require from = "./converters"></require>
<h3>${currentDate | dateFormat}</h3>
</template>
แปลงสกุลเงิน
นี่คือตัวอย่างของการจัดรูปแบบสกุลเงิน คุณจะสังเกตเห็นว่าแนวคิดนั้นเหมือนกับในตัวอย่างข้างต้น ขั้นแรกเราต้องติดตั้งnumeral ห้องสมุดจากไฟล์ command prompt.
C:\Users\username\Desktop\aureliaApp>jspm install numeral
Converter จะกำหนดรูปแบบสกุลเงิน
converters.js
import numeral from 'numeral';
export class CurrencyFormatValueConverter {
toView(value) {
return numeral(value).format('($0,0.00)');
}
}
View-model จะสร้างตัวเลขสุ่ม เราจะใช้สิ่งนี้เป็นมูลค่าสกุลเงินและอัปเดตทุกวินาที
app.js
export class App {
constructor() {
this.update();
setInterval(() => this.update(), 1000);
}
update() {
this.myCurrency = Math.random() * 1000;
}
}
มุมมองของเราจะแสดงตัวเลขที่สร้างขึ้นแบบสุ่มที่แปลงเป็นสกุลเงิน
app.html
<template>
<require from = "./converters"></require>
<h3>${myCurrency | currencyFormat}</h3>
</template>