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>