riot.js學習【四】表達式+Boolean屬性
表達式
在riot.js中,html標籤,可使用比較強大的表達式,來設值。
表達式可用在 innerText, attributes 中,而且100%原汁原味的JavaScript語法。
給幾個小examples:
<h3 id={ /* 属性表达式 */ }> { /*这里可以写表达式*/ }</h3>
使用方式也是蠻豐富的:
{ title || 'da宗熊' } { isReady ? 'ready' : 'loading' } { new Date() } { this.getName() } { Math.round(10) } { message.length > 100 && '消息太长了~' }
riot.js的表達式,讓你的html盡可能的整潔,高效。
當然如果你的表達式太複雜,可以考慮把計算放在 update事件,或獨立一個計算方法。
<todo> <!-- value的计算很复杂 --> <p>{ value }</p> <p>{ this.getText(this.text) }</p> // 计算复杂的表达式 this.on("update", function(){ var d = new Date(); this.value = d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate(); }); this.text = "da宗熊"; // getText方法,会依赖于this对象下 getText(text){ return "你好" + text; } </todo>
輸出如下:
Boolean 屬性
像checked, selected等屬性,在roit.js中,就稱為Boolean屬性。
如果Boolean屬性的表達式值為false,那麼該屬性將會被忽略:
<!-- 普通属性 --> <input name={ false } > <!-- Boolean属性 --> <input checked={ null } >
將會產生:
<input name="false" ><input >
W3C規範中說明,只要Boolean屬性存在,那它就肯定是true,甚至將它的值甚至為false,但它仍然為true。
簡單來說,就是就算我們設定了 checked=false,但最終瀏覽器出來的效果,還是被勾選狀態。
針對這一點,roit.js對Boolean屬性,在產生時,進行了最佳化,如果是Boolean屬性,而且它的表達式的滿足條件:
{ value == false }
都將不會產生該Boolean屬性。
新手遇坑
屬性設定
<input value={ name } { isCheck ? 'checked' : '' } />
這樣的設定是禁止的,生成的,將會是這樣的代碼:
<input {="" true="" ?="" 'checked'="" :="" ''="" }="">
表示完全看不懂,有木有?
雙引號
<input name={ "da宗熊" } >
看著很正常啊,有木有?
但結果代碼是:
<input da宗熊"="" }"="" name="{ ">
再次強調,riot.js就跟雙引號有仇! ! ! ! 【大部分情況下】
以上就是riot.js學習【四】表達式+Boolean屬性的內容,更多相關內容請關注PHP中文網(www.php.cn)!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Python作為一種高階程式語言,易於學習和使用。一旦需要編寫Python程式時,無法避免地遇到語法錯誤,表達式語法錯誤是常見的一種。在本文中,我們將討論如何解決Python的表達式語法錯誤。表達式語法錯誤是Python中最常見的錯誤之一,它通常是由於錯誤的使用語法或缺少必要組件而導致的。在Python中,表達式通常由數字、字串、變數和運算子組成。最常見的

Lambda表達式,顧名思義,就是一種以箭頭符號(->)為核心的匿名函數。它允許你將程式碼區塊作為參數傳遞給其他方法,或將其儲存到變數中以供以後使用。 Lambda表達式語法簡潔、易於理解,非常適合處理資料流和平行計算。 1.Lambda表達式的基本語法Lambda表達式的基本語法如下:(參數列表)->{程式碼區塊}其中,參數列表和程式碼區塊都是可選的。如果只有一個參數,可以省略括號。如果程式碼區塊只有一行,可以省略大括號。例如,以下程式碼區塊使用Lambda表達式實現了將數字加1的功能:List

在C或C++中,逗號「,」有不同的用途。在這裡我們將了解如何使用它們。逗號作為運算符。逗號運算符是一個二元運算符,它計算第一個操作數,然後丟棄結果,然後計算第二個運算符並傳回值。逗號運算子在C或C++中的優先權最低。範例#include<stdio.h>intmain(){ intx=(50,60); inty=(func1(),func2());}這裡60將被指派給x。對於下一語句,將會先執行func1(

C語言中指數函數表達式的寫法介紹及代碼範例什麼是指數函數指數函數是數學中一類常見的函數,可以表示為f(x)=a^x的形式,其中a為底數,x為指數。指數函數主要用來描述指數成長或指數衰減的情況。指數函數的程式碼範例在C語言中,我們可以使用數學庫中的pow()函數來計算指數函數,以下是一個範例程式:#include

Java中的lambda表達式隨著Java8的發布,lambda表達式成為了Java開發者們最關注和討論的話題之一。 Lambda表達式可以簡化Java程式設計師繁瑣的書寫方式,同時也能夠提升程式的可讀性和維護性。在本文中,我們將深入探討Java中的lambda表達式,以及它們如何在Java程式碼中提供更簡單、更直覺的程式設計體驗。

lambda表達式是一種匿名函數,它可以很方便地用於遍歷集合。在這篇文章中,我們將介紹如何使用lambda表達式遍歷集合,並提供具體的程式碼範例。在Python中,lambda表達式的語法格式如下:lambda參數列表:表達式lambda表達式的參數列表可以包含一個或多個參數,並用逗號隔開。表達式是lambda函數的回傳值。下面我們來看一個簡單的例子,假設

Lambda表達式的簡介與基本語法Lambda表達式由一個函數參數列表,一個冒號和一個函數體組成。函數參數列表與普通函數的參數列表相同,函數體則是表達式,而不是一組語句。 #範例:傳回一個函數,該函數接收兩個數字並傳回它們的和sum=lambdax,y:x+yLambda表達式的應用程式場景Lambda表達式非常適合用作回調函數、濾波器函數和映射函數。回調函數:回呼函數是指在另一個函數中呼叫的函數。 Lambda表達式可以輕鬆建立回呼函數,而無需聲明其名稱。濾波器函數:濾波器函數用於從序列中過濾出滿

隨著電腦技術的快速發展,程式語言也不斷地升級和完善。其中,PHP作為常用的Web開發語言,也不斷地推陳出新,不斷推出新的版本。最近,PHP8.0版本的發布引起了廣泛的關注。其中,新版本中對於異常處理機制的改進引起了許多人的注意。本文將圍繞著PHP8.0中的try語句區塊支援表達式這個主題展開討論。一、PHP8.0異常處理機制的改進在先前的版本中,P
