FIRST LINE 企業級客服系統
🫱 官方網站🔥 最新消息
  • ❤️關於 FIRST LINE
    • 🥰客服中心
    • 📔更新日誌
      • 🐍2025
      • ☎️電話管理系統
      • 🍱Archive
        • 🐲2024
        • 🐰2023
        • 🐯2022
        • 🐮2021
        • 🐭2020
  • 指南與解答
    • 🚀指南
      • 🤖打造專屬聊天機器人
      • 🧠FIRST LINE AI
      • 🏗️管理者系統建置
      • 👋客服人員:訊息服務
      • 📥服務台:解決與紀錄客戶問題
      • 🔃交談分派的運作模式
      • 💬3 種 WhatsApp 帳號種類大解析!
    • 📔名詞解釋
    • ❓系統疑難
      • ⚠️提示或告警訊息
      • 📶網路離線提醒
      • 🌎支援的瀏覽器
      • 🪠清除瀏覽器快取
  • 功能教學
    • 💬管道
      • 💬即時聊天
        • 疑難雜症
        • 客戶身份驗證
        • 安裝範例
          • 嵌入至 LINE 內服務客戶
          • 安裝於 SHOPLINE 內
          • 安裝於 Shopify 內
      • 💬LINE 官方帳號
        • 如何啟用 Messaging API
        • LINE 訊息費用怎麼算
        • LINE Developer 相關
      • 💬Facebook Messenger
        • 疑難雜症
        • 錯誤代碼 #2022
      • 💬Instagram
      • 💬微信公眾號
      • 💬WhatsApp (Cloud API)
        • 疑難雜症
      • 💬WhatsApp (Twilio)
      • 💬Telegram
      • 💬Viber
      • 📮電子信箱
        • 電子郵件分隔文本
        • 電子郵件附件
        • Gmail 串接測試
      • 📱簡訊
        • Twilio
        • 三竹簡訊
      • ☎️電話
        • ❓疑難雜症
        • 👨‍💻調整或分配分機給專員
        • 📕通話時服務紀錄沒有建立
        • ⤴️轉接與三方通話
        • 😃座席狀態
        • ☎️電話 SIP 代碼
        • 📊通話資訊
      • 🏪線上下通路
    • 📈儀錶板
      • 📊服務水平
      • ☎️電話
      • ☎️專員電話即時狀態
      • 😃社群媒體好友數
      • 📈訊息統計
      • 💬交談佇列
    • 😀客戶關係管理
      • 😀客戶
        • 🔃客戶合併
      • 🏢公司
      • ⬇️匯入客戶
      • 匯入自訂表格
      • 🤝服務紀錄
        • 💬交談紀錄
      • 🔖服務結果
      • ✏️服務原因
      • 自訂欄位
      • 資料匯出
      • 電話紀錄
    • 🤖聊天機器人
      • 📒交談腳本
        • ❓疑難雜症
        • 🚀功能詳解
          • 🧠FIRST LINE AI
          • 📃模組腳本
          • 🔜分派權重
          • 📒事件紀錄
          • 📔草稿與發佈
          • 🗂️輪播訊息
          • 🔘按鈕行為
        • 🎬情境範例
          • 串接 ChatGPT
          • 搜尋與回覆知識庫文章
          • 緊急信件轉派
          • 封鎖名單
          • Webhook 整合指南
          • 如何透過 API 溝通
        • 📊統計數字
        • 從即時聊天 URL 添加數據
      • 😀滿意度調查
      • 🧠AI 訓練資源
      • 🕐營業時間
      • 🤖自動回應
        • 關鍵字回應
    • 💡知識庫
      • 幫助中心
        • 擴充自訂義 HTML
      • 聊天機器人
    • 🎟️工單
      • 工單範本
      • 關注工單
      • 透過電子信箱發送
      • 狀態細項
    • 🛍️行銷
      • 🛍️產品目錄
      • 📢分眾訊息
        • 自動化活動
      • 🎡LINE 圖文選單
      • 📃貼文自動回覆
      • 😁對話角色
      • 🎟️優惠卷
      • 🔗追蹤連結
    • 🔌整合
      • 🚗自動化
        • 範例:發送 LINE 訊息
        • 範例:會員同步
        • 範例:發送 Teams 通知
      • ⛓️Webhook 腳本
    • 📃報表
      • ☎️電話
        • 專員通話效率
        • 通話紀錄報表
        • ACD 號碼分析
      • 服務紀錄明細與樞紐
      • 專員服務效率
      • 訊息管道樞紐
    • ⚒️輔助工具
      • 管道整合
      • 信件範本
      • 對話腳本
      • 訊息範本
    • ⚙️系統設定
      • 🏢企業
        • 🏢系統設定
        • 🧑‍🤝‍🧑部門
        • 💰帳務總覽
        • 🔥IP 允許清單
        • 組別
        • 業主
        • 🗺️地址
          • 縣市
          • 行政區域
          • 國家
        • 🔐權限
      • 😀客戶
        • 客戶分派
      • 🤝服務紀錄
        • 服務原因
      • 🎙️員工
        • 服務狀態
        • 更改或忘記密碼
      • 🗄️檔案管理
      • 💪技能
      • 👜職位
      • 💬開場白與話術
    • 🚀其他資料
      • 🔵Fancy 點數
      • 👨‍💻模板語法
      • 💬交談狀態
      • 🔍全域搜尋
      • 👨‍💻交談腳本變數
      • 📄資料欄位類型
      • 🌐IP 與網域清單
      • 💬各管道訊息類型支援度
    • ✊合作夥伴
      • 📞電話疑難雜症
      • 🎛️其他相關設定
  • 開發文件
    • API 說明
      • 請求方式說明
      • 回應物件資料
      • 😀客戶
      • 🔖客戶標籤
      • 🏢公司
      • ⬇️客戶匯入排程
      • ⬇️客戶自訂表格匯入排程
      • 📄自訂欄位主分類
      • 📄自訂欄位
      • 📄自訂表格
      • ☎️電話號碼
      • 🌎國家、縣市及區域
      • 🏠地址
      • 📧電子信箱
      • 🎫工單
      • 💬服務紀錄
      • 😃滿意度調查
      • 🛍️產品
      • 📄訂單
      • 📦訂單品項
    • Advanced
      • 透過 Hash 值取得 Text-Call ID
      • 透過 Text-Call ID 發送訊息
      • 搜尋聯絡人資料(Partner Limit)
      • Push (Partner Limit)
    • 即時聊天 Javascript API
Powered by GitBook
On this page
  • 概述
  • 變數命名規則
  • 符號與運算子
  • 分隔符
  • 算術運算子
  • 比較運算子
  • 條件(三元)運算子
  • 邏輯運算子
  • 流程控制
  • if...else
  • for
  • 文字過濾器
  • 運算子
  • 字串分割
  • 日期過濾器
  • 顯示當前時間
  • 指定時區
  1. 功能教學
  2. 其他資料

模板語法

概述

本篇文章將介紹模板語法,透過使用變數和表達式,您可以輕鬆地構建所需的內容並進行置換。

而模板語法目前可套用於以下功能:

  • 對話腳本中部分訊息操作。

  • Webhook 腳本中的參數 Params 與回呼 (Callback)。

變數命名規則

如同多數的程式語言,如 python、JavaScript ..等,交談變數必須遵從以下規則:

  1. 變數名稱必須以字母(a-z、A-Z)或下底線(_)開頭。

  2. 後續的字元可以是字母、數字(0-9)或下底線(_)。

  3. 變數的命名是區分大小寫的,大寫字母(A-Z)和小寫字母(a-z)被視為不同的字元。

以下是一些符合命名規則的變數名稱的範例:

  • myVariable

  • count

  • first_name

  • age123

符號與運算子

分隔符

模板語法採用 {{ ... }} 與 {% ... %} 兩種符號表達,前者分隔符號將替換為實際字串輸出於內容中,如下面語法顯示,將實際輸出為「王小明,您好!」。

{{ name }},您好!

而也可以透過一個點.(dot)符號來顯示變數更深層的內容,例如

{{ contact.first_name }}

{# 也能透過方括號存取內容 #}
{{ contact['first_name'] }}

而後者 {% ... %} 分隔符號,則用於執行邏輯操作,如 for、if ...等。

{# 設定變數 name 為王小明 #}
{% set name = '王小明' %}

{# 這邊會顯示 0,1,2,3 依序到 10 #}
{% for i in range(0, 10) %}
    {{ i }}
{% endfor %}

算術運算子

模板提供簡易的運算符號,其他包括以下

運算子
語法範例
結果
說明

+

{{ 1 + 2 }}

3

加法,只適用於數值,不可用來串接字串

-

{{ 5 - 3 }}

2

減法

*

{{ 4 * 2 }}

8

乘法

/

{{ 5 / 2 }}

2.5

除法

//

{{ 7 // 2 }}

3

整數除法(取商)

%

{{ 11 % 7 }}

4

取餘數

比較運算子

能直接透過 == 、!=、 <、 >、 >= 和 <=,並基於比較的結果回傳邏輯值。

  • ==:等於。

  • -!:不等於。

  • <:小於。

  • >:大於。

  • >=:大於或等於。

  • <=:小於或等於。

針對更為複雜的比較,則可使用 matches匹配操作符透過正則表達式比較。

{% if phone_number matches '/^[\\d\\.]+$/' %}
{% endif %}

條件(三元)運算子

這個運算子能接受兩個運算元作為值並且一個運算元作為條件判斷。而 語法是:條件 ? 數值1 : 數值2 ,下方為一些簡單範例。

{{ name ? 'yes' : 'no' }}

{{ age >= 18 ? '成人' : '小孩' }}

邏輯運算子

能透過 ?? 判斷 OR 邏輯,假如 運算式1 可以為是的話,回傳 運算式1; 否則,反之回傳 運算式2。

{# 如果 age 已被不是空值,则顯示 name 的值,反之則顯示 unknown #}
{{ name ?? 'unknown' }}

流程控制

流程控制是指控製流程的條件語句,如if、elseif、else、for等。控制語法應放置在 {% ... %} 分隔符內容中。

if...else

當條件成立的時候會執行 if 陳述式裡的語法,而不成立時則執行另外一個陳述式。

{% if age >= 18 %}
    成年
{% else %}
    未成年
{% endif %}

{# 判斷數值是否存在 #}
{% if users is defined %}
  {{ user.username }}
{% endif %}

for

不斷重複直到一個指定的條件式判斷為 false,直到條件不符合才停止執行,其中 for 的區塊內,你能使用內建的特殊變數。 特殊變數如下:

變數名

描述

loop.index

顯示當前 index(索引),由 1 開始

loop.index0

顯示當前 index(索引),由 0 開始

loop.length

陣列的長度

loop.first

返回 true,若為陣列最初項目

loop.last

返回 true,若為陣列最後項目

{% for user in users %}
    {{ user.name }}
{% endfor %}

{# 你也可以搭配 else 判斷陣列是否空值時,如 #}
{% for user in users %}
    {{ loop.index }} - {{ user.name }}
{% else %}
    No users have been found.
{% endfor %}

以下是根據你提供的語氣與格式,為 split 用法撰寫的一段說明,可直接接續於原本的教學內容中使用:


文字過濾器

運算子

運算子 / 方法
語法範例
結果 / 功能
說明

~

{{ 'Hello, ' ~ name }}

Hello, Eason

字串拼接運算子,會自動將變數轉成字串,即使為 null

字串分割

當需要將一段文字依照某個符號拆解為多個部分時,可使用 split 功能。例如將一段姓名依照每個字元拆分為清單資料,便能逐一取用各字:

{{ name|split('') }}

{# 若 name 為「王小明」,執行後將得到: #}
['王', '小', '明']

也可以指定特定符號作為切割依據,例如以逗號分隔的顏色標籤:

{{ 'red,blue,green'|split(',') }}

{# 結果為: #}
[['red', 'blue', 'green']

分割後的資料可透過 for 語法進行逐一處理,常用於顯示標籤、分解文字內容等需求。

日期過濾器

日期語法可接受字串、DateTime 物件。例如,要顯示當前日期,請將單字 “now” 作為語法的參數。

顯示當前時間

// 輸出為 2022-05-12 22:21:10
{{ 'now' | date('Y-m-d H:i:s') }

指定時區

預設情況下,日期會套用 FIRST LINE 伺服器的時區顯示,但您可以透過明確指定時區來覆寫它:

// 指定特殊時區換算
{{ 'now' | date('Y-m-d H:i:s', 'Asia/Tokyo') }}

如果日期已經是 DateTime 物件,且您想要保持其當前時區,請將時區值傳遞為 false。

{{ product.created_at | date('Y-m-d H:i:s', false) }}
PreviousFancy 點數Next交談狀態

Last updated 9 days ago

🚀
👨‍💻