JSX有感

来源:https://www.cnblogs.com/apolis/archive/2018/11/22/10004055.html
-Advertisement-
Play Games

寫JS時,不斷翻看HTML,確保`querySelector`能取到期望的元素。 改HTML時,一個個排查JS文件,確保其沒受影響。 類似的情況很影響我們工作效率。 ...


開發一個網頁,我們要寫視圖部分HTML,也要寫交互邏輯JS。

寫JS時,不斷翻看HTML,確保querySelector能取到期望的元素。
改HTML時,一個個排查JS文件,確保其沒受影響。
……
類似的情況很影響我們工作效率。

把視圖和相關的邏輯放在一起,成為了大家迫切的需求。

就這一問題,我們來看看不同的解決思路。

ExtJS

視圖部分也用JS來寫,自然很容易放在一起了。

Ext.define('XXX.view.Alarm', {
    extend: 'Ext.container.Container',
    xtype: 'alarmpanel',

    initComponent: function () {
        Ext.apply(this, {
            layout: 'border',

            items: [{
                xtype: 'hsnavtree',
                itemId: 'leftTree',
                store: Ext.getStore('AlarmNavTree'),
                cls: 'left-directory',
                rootVisible: false,
                region: 'west',
                width: 240
            }, {
                xtype: 'container',
                itemId: 'centerContainer',
                layout: 'fit',
                region: 'center'
            }]
        });
        this.callParent(arguments);
    }
});

layout: 'border'指定佈局方式為東南西北中。
items中每一項的region指定是東南西北中的哪一部分。


JSX

在JS中直接寫HTML,再通過編譯轉成JS。(思想是這樣,但大家知道和HTML還是有區別的。)

class ShoppingList extends React.Component {
    render() {
        return (
            <div className="shopping-list">
                <h1>Shopping List for {this.props.name}</h1>
                <ul>
                    <li>Instagram</li>
                    <li>WhatsApp</li>
                    <li>Oculus</li>
                </ul>
            </div>
        );
    }
}

兩種思路都做到了“把視圖和相關的邏輯放在一起”。

我想JSX贏在了:

  1. 大家都熟悉HTML,學JSX比學ExtJS那套layout輕鬆,而且也覺得直觀。
  2. 大家越來越追求Dom的語義化,ExtJS生成的Dom太不語義化了。

不過JSX這樣的思想,也並不算新思想,2009年我接觸Flex的時候也見識過。

Flex在ActionScript的基礎上發展出了mxml,用xml的形式寫視圖,再編譯成ActionScript。

JSX -> JavaScript  
mxml -> ActionScript

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 跳轉 命名路由 在文件構建時先設置路由參數: 在需要做路由跳轉的時候直接使用: 構建路由 區別 以上兩種路由的優缺點十分明顯: 1. 命名路由簡明並且系統,但是不能傳參。 2. 構建路由可以傳參,但比較繁瑣。 動畫 構建動畫 先在構建一個動畫效果,如: 以上動畫意思為跳轉時新頁面從右邊劃入,返回時向 ...
  • 這裡記錄兩個iOS開發中經常用到的知識點,一個是唯一標識,一個是全局變數。唯一標識一臺設備(比如iPhone、iPad等)是一個基本的實現與業務上的需求,因為這個唯一標識在許多場景都需要使用到,比如用來統計(日活、總用戶數等),再比如用作預設的賬號,等等。 ...
  • 平時在使用Vue框架的業務開發中,組件不僅僅要把模板的內容進行復用,更重要的是組件之間要進行通信。組件之間通信分為三種:父-子;子-父;跨級組件通信。下麵,就組件間如何通信做一些總結。 1.父組件到子組件通過props通信 在組件中,使用選項props來聲明需要從父級組件接受的數據,props的值可 ...
  • 在開發的過程中,遍歷是一個經常遇到的。而for迴圈則是Javascript工具箱里一個好用的,也常用的工具。每個人的習慣不同,for迴圈的寫法也不盡相同。 1、不寫聲明變數的寫法: 我們很多時候的寫法使這種(做小白不堪迴首的那些年),但這種寫法,每次都會獲取一下數組的長度,這會降低代碼的效率。 2、 ...
  • Vue源碼解析之nextTick 前言 nextTick是Vue的一個核心功能,在Vue內部實現中也經常用到nextTick。但是,很多新手不理解nextTick的原理,甚至不清楚nextTick的作用。 那麼,我們就先來看看nextTick是什麼。 nextTick功能 看看官方文檔的描述: 在下 ...
  • 摘要: 本插件基於layui.layedit,增加了HTML源碼模式,片插入功能添加alt屬性(layupload),視頻插入功能,全屏功能,段落格式,字體顏色設置,右鍵菜單操作,插入錨點,水平線功能。 所有拓展功能菜單按鈕圖標均引用自layui自帶圖標。 演示地址:kz.layedit 一、基礎拓 ...
  • RegExp語法(包含ES2018標準) 註意:本次所有代碼都僅在Chrome 70中進行測試 1. 正則表達式是什麼? 正則表達式是用於匹配字元串中字元組合的模式。(mdn) 簡單來說,正則表達式是用來提取、捕獲文本(匹配字元)的。 2. 創建: 字面量: 構造函數: 3. 實例屬性: 每個正則表 ...
  • 安裝 cordova 新建項目 運行項目 編譯項目 修改編譯輸出 打開vue項目目錄下麵的index.html,添加 打開/config/index.js 編譯打包 先刪除 cordova項目下的www文件夾里的東西 執行編譯vue項目將輸出到 cordova 項目目錄下的www文件內 添加andr ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...