Angular與React的一些看法

来源:http://www.cnblogs.com/code2life/archive/2016/01/03/5097515.html
-Advertisement-
Play Games

Angular - React之爭Angular和React無疑是目前最受追捧的兩個前端框架,谷歌也發現Angular1.x不足的地方,開始開發2.0版本,臉書發現React的組件化和虛擬DOM非常好,也同時投資React Native。00.先比較Angular1.x與React這兩個沒什麼可比性...



Angular - React之爭

Angular和React無疑是目前最受追捧的兩個前端框架,谷歌也發現Angular1.x不足的地方,開始開發2.0版本,臉書發現React的組件化和虛擬DOM非常好,也同時投資React Native。

00.先比較Angular1.x與React

這兩個沒什麼可比性,Angular著重數據綁定和前端MVC,以及不同模塊的依賴註入。React著重於組件化和性能。之前做項目用的Angular,數據綁定很爽,但是作為新手學習曲線確實很陡峭,寫個指令不知道scope飛哪裡去了,用Angular-UI又要去FQ查各種聲明方式,總之踩了很多坑。某一天看到React,確實有種眼前一亮的感覺,因為時間不多,當時也就沒深入瞭解了。React給人一種小清新的感覺,Virtual DOM的思路比Angular的$digest迴圈明顯好一點,然而Angular火的早,參考的東西很多,這兩者各有優劣吧。長期來看React會比Angular更好,畢竟谷歌已經把重點放在Angular2.x上面了,有些放棄1.x的感覺。

01.再比較Angular2.0與React Native

筆者走馬觀花的看了這兩個框架,發現兩者有很多共同點。比如都選擇了ES6的語法,用一個class來聲明組件,比如都著眼於組件化,再比如都抽象出渲染模塊,能在不同平臺復用。而兩者不同的地方是:

Angular2比React Native的語法更優雅,更像是聲明式的語法。命令式走向聲明式無疑是一門語言進步的標誌,好比蓋一棟房子,命令式像是找土,找磚窯,一塊一塊燒,聲明式好比打電話給磚廠,“明天XX點送1000塊磚過來”,React Native的一些語法相比於Angular2顯得更帶有命令式的意味,比如getInitialState,這是一個View設置初始狀態和初始化數據的API,這相比與Angular2使用class的構造器語法顯得有些不優雅了。

具體的例子比較一下:

import {Component} from "angular2/core";
import {bootstrap} from "angular2/platform/browser";

@Component({
    selector:"ez-card",
    properties:["name","country"],
    template : `<div class='ez-card'>
            My name is <b>{{name}}</b>, 
            I am from <b>{{country}}</b>.</div>`
})
class EzCard{
    constructor(){
        this.name = "Mike";
        this.country = "Sweden";
    }
}
var React = require('react-native');
var {
  AppRegistry,
  Image,
  ListView,
  StyleSheet,
  Text,
  View,
} = React;

React.createClass({
  getInitialState: function() {
    return {
      dataSource: new ListView.DataSource({
        rowHasChanged: (row1, row2) => row1 !== row2,
      }),
      loaded: false,
    };
  },
  render : function(){
    return (
      <ListView
        dataSource={this.state.dataSource}
        renderRow={this.renderMovie}
        style={styles.listView}
      />
  } 
  }
});

上面兩段代碼是從一些教程上摘下來的部分片段,純ES6語法的Angular2看起來明顯更清爽一點,而且Angular2看樣子是要實現Write Once,Run Anywhere:

而React的重點是Web應用,React Native註重原生平臺的底層調用,Learn Once,Write Anywhere是否會造成冗餘的開發也有待考量,但原生介面調用以及組件化的開發方式一定會比目前hybrid app的模式更加靠譜,性能更好,可維護性更高。

10.總結

組件化和聲明式的開發一定會成為主流,ES6也會慢慢普及,React以及React Native已經獲得了不錯的聲譽,Angular1.x已經功成名就,Angular2蓄勢待發,如果Angular2能在短時間範圍內實現IOS和安卓的渲染應該會與React Native、現存的很多hybrid app競爭並且得到一席之地的。


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

-Advertisement-
Play Games
更多相關文章
  • 預覽截圖:製作步驟:一, 標簽結構下麵代碼中使用了CSS3無首碼腳本prefixfree.js,可以省去CSS3中首碼“-moz”、“-webkit”、“-o”、“-ms”button 二, 標簽結構 三,C...
  • 由於我在項目中用jquery比較多,而且覺得jquery真的很不錯,尤其是其靈活高效的選擇器更是令人無法忘懷。那麼,今天就來寫一篇非常基礎的關於jquery選擇器的文章,路過的朋友可以收藏以作參考。1、$("*") -- 選取所有元素* 選擇器選取文檔中的每個單獨的元素,包括 html、head 和...
  • 在這篇文章里,我將分享一些JavaScript的技巧、秘訣和最佳實踐,除了少數幾個外,不管是瀏覽器的JavaScript引擎,還是伺服器端JavaScript解釋器,均適用。1、首次為變數賦值時務必使用var關鍵字變數沒有聲明而直接賦值得話,預設會作為一個新的全局變數,要儘量避免使用全局變數。2、使...
  • 1. 不同瀏覽器元素的預設屬性有所不同,使用Reset可重置瀏覽器元素的一些預設屬性,以達到瀏覽器的相容。/** 清除內外邊距 **/body, h1, h2, h3, h4, h5, h6, hr, p, blockquote,/* structural elements 結構元素 */dl, d...
  • 摘要: 最近在開發項目中又用到了前端分頁,以前也做過,為了方便以後使用所以將他封裝成第三方插件,不依賴任何庫。網上已經有很多插件,問什麼還要自己造輪子?自己寫的擴展性高不依賴任何庫作為一次技術沉澱線上預覽:http://baixuexiyang.github.io/pagination/項目地址:....
  • D2前端技術論壇(Designer & Developer Frontend Technology Forum),簡稱D2。為國內前端開發者和網站設計師提供一個交流的機會,一起分享技術的樂趣,探討行業的發展,以技術會友。它是中國所有前端開發者的節日,包括前端設計師,前端開發工程師,和所有對前端技術....
  • 1. fill() arr.fill(value, [start], [end]) fill()方法向數組的開始位置到結束位置填充一個靜態值 參數: value: 要填充的值 start: 可選。開始位置,預設為0 end: 可選。結束位置,預設為length-1 返回: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...