成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

和其他庫(jquery,backbone)一起使用react

ckllj / 3360人閱讀

摘要:也就是說,只要一發(fā)生事件。和其他的庫共用由于方法的靈活性使得可以被嵌入到其他的應(yīng)用中。事實上,這就是在被使用的方式。在應(yīng)用中使用的層在組件中消費中和最簡單的方法是監(jiān)聽各種事件并手動進行強制更新。并且使用組件來渲染各個項。

注:由于譯者水平有限,難免會出現(xiàn)錯誤,希望大家能指出,謝謝。

react 可以被用在任何的web 應(yīng)用中。它可以被嵌入到其他的應(yīng)用中,要是你小心一點,其他的應(yīng)用也能被嵌入到react中。這篇文章將會從一些常用的使用場景入手,重點會關(guān)注與jQuery 和backbone 的交互。但是里面的思想在我們和其他庫交互時都是可以被參考的。

和操縱DOM的插件的交互

react 感知不到它管理之外的dom 的變化。react的更新是取決于其內(nèi)部的表現(xiàn),如果同樣的DOM節(jié)點被其他可操作dom節(jié)點的插件更改了,react內(nèi)部狀態(tài)就會變的很混亂并且無法恢復(fù)了。

這并不意味著react 無法和那些操縱DOM 的插件一起共用,你只需要更加清楚每個插件做了什么。

最簡單的避免這種沖突發(fā)生的方式是阻止react 組件的更新。你可以通過渲染一個react 沒有必要去更新的元素,比如一個空的

如何處理這種問題

為了更好的闡述這個問題,讓我們來對一個一般的jquery 插件添加一個wrapper。

首先,我們在這個節(jié)點上添加一個ref屬性。在componentDidMount 方法里,我們通過獲取這個節(jié)點的引用,將它傳給jquery 插件。

為了避免react 在渲染期間對這個節(jié)點進行改變, 我們在render() 方法里面返回了一個空的

.這個空的節(jié)點沒有任何的屬性或子節(jié)點,所以React 不會對該節(jié)點進行更新,這個節(jié)點的控制權(quán)完全在jQuery插件上。這樣就不會出現(xiàn)react 和jquery 插件都操作同樣的dom 的問題了。

class SomePlugin extends React.Component {
  componentDidMount() {
    this.$el = $(this.el);
    this.$el.somePlugin();
  }

  componentWillUnmount() {
    this.$el.somePlugin("destroy");
  }

  render() {
    return 
this.el = el} />; } }

需要注意的是,我們定義了componentDidMount() 和componentWillUnmount() 兩個生命周期的鉤子函數(shù)。這是因為大多數(shù)的jQuery插件都將事件監(jiān)聽綁定在DOM上,所以在componentWillUnmount 中一定要移除事件監(jiān)聽。如果這個插件沒有提供移除的方法,那你就要自己寫了。一定要記得移除插件所注冊的事件,否則可能會出現(xiàn)內(nèi)存泄露。

和jQuery 的選擇器插件共用

為了對這些概念有更深入的了解,我們?yōu)镃hosen 插件寫了一個小型的wrapper。Chosen 插件的參數(shù)是一個 節(jié)點應(yīng)用了該組件。它會讀取原始DOM節(jié)點的屬性,使用內(nèi)聯(lián)樣式隱藏它。并且使用自己的展示方式在

class Chosen extends React.Component {
  render() {
    return (
      
); } }

需要注意的是,我們在標(biāo)簽后面添加一個傳入的節(jié)點。然而,就React而言,

標(biāo)簽通常只有一個孩子節(jié)點。這就是我們?nèi)绾未_保React 的更新不會和通過Chosen 插入的額外的DOM節(jié)點沖突的原因。很重要的一點是,如果你在React 流之外修改了DOM節(jié)點,你必須確保React 不會因為任何原因再對這些DOM節(jié)點進行操作。

接下來,我們繼續(xù)實現(xiàn)生命周期的鉤子函數(shù)。我們需要在componentDidMount里使用 this.el = el}>

以上對于在render 里面獲取你的組件就足夠了,但是我們還希望值變化時能給實現(xiàn)通知。因為,我們通過Chosen 在中的屬性this.props.children 的更新。但是我們同時也在componentDidUpdate 的生命周期函數(shù)里添加通知Chosen 他的children 列表變化的函數(shù)。

componentDidUpdate(prevProps) {
    if (preProps.children !== this.props.children) {
        this.$el.trigger("chosen:updated");
    }
}

通過這種方式,當(dāng)通過React 管理的 this.el = el}> {this.props.children}

); } } 和其他的View 庫共用

由于ReactDOM.render()方法的靈活性使得React可以被嵌入到其他的應(yīng)用中。

由于React 通常被用來將一個React 節(jié)點渲染到某個DOM元素中,而且ReactDOM.render()可以被UI的各個獨立的部分多次調(diào)用,小到一個按鈕,大到一個app。

事實上,這就是React 在Facebook 被使用的方式。這使得我們可以在React 中一塊一塊的開發(fā)一個應(yīng)用,并且可以把它整合在現(xiàn)有的服務(wù)器渲染的模版中或者其他的客戶端代碼中。

使用React替換基于字符串的渲染

在一些老的web 應(yīng)用,一種常見的方式是寫一大段DOM結(jié)構(gòu)作為字符串,然后使用$el.html(htmlString) 的方式插入到DOM節(jié)點中。如果你的代碼庫中有類似的場景,那么推薦你使用react。你只需要將使用字符串渲染的部分改成react 組件就可以了。
下面是一個jQuery 的實現(xiàn)

$("#container").html("");
$("#btn").click(function() {
  alert("Hello!");
});

改成react 的實現(xiàn)

function Button() {
  return ;
}

ReactDOM.render(
  

接下來,你可以將更多的業(yè)務(wù)邏輯移到react組件中去并且采用更多react 實踐方式。例如,組件最好不要依賴id,因為同樣的組件可能會被渲染多次。而且,我們推薦使用react 的事件系統(tǒng),直接在組件; } function HelloButton() { function handleClick() { alert("Hello!"); } return

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88570.html

相關(guān)文章

  • 2017年前端流行的數(shù)百個javascript,你會幾個?

    摘要:有數(shù)百個免費的庫出來,為應(yīng)用程序選擇正確的框架變得非常困難。是流行的驅(qū)動技術(shù)之一,由于年創(chuàng)建。在這三個塊中,有幾個暴露低層接口的綁定。反應(yīng)由,和許多開發(fā)人員和個人的社區(qū)維護。誕生于年,是一個輕量級的框架。 有數(shù)百個免費的JS庫出來,為應(yīng)用程序選擇正確的JavaScript框架變得非常困難。一些開發(fā)商最終會拋棄,而其他開發(fā)者則迅速發(fā)展,并得到廣泛采用。許多開發(fā)人員只知道像jQuery和R...

    CoXie 評論0 收藏0
  • 《高性能JavaScript》(讀書筆記)

    摘要:加載的模塊會以參數(shù)形式傳入該函數(shù),從而在回調(diào)函數(shù)內(nèi)部就可以使用這些模塊。異步加載,和,瀏覽器不會失去響應(yīng)它指定的回調(diào)函數(shù),只有前面的模塊都加載成功后,才會運行,解決了依賴性的問題。插件,可以讓回調(diào)函數(shù)在頁面結(jié)構(gòu)加載完成后再運行。 這次主要是對《高性能JavaScript》一書的讀書筆記,記錄下自己之前沒有注意到或者需要引起重視的地方 第一章 加載和執(zhí)行 js代碼在執(zhí)行過程中會阻塞瀏覽...

    moven_j 評論0 收藏0
  • 前端MVC手腳架

    摘要:前端手腳架項目地址構(gòu)建工具基礎(chǔ)庫這個項目類似,主要是用于記錄,以及考察現(xiàn)在比較流行的前端庫在實際開發(fā)當(dāng)中的開發(fā)體驗。其中,構(gòu)建都是基于,支持語法但在中,只用到的模塊管理與析構(gòu)語法。 前端MVC手腳架 項目地址 https://github.com/lizzz0523/mvc-mode-seed 1.構(gòu)建工具 [x] webpack [x] babel-loader [x] babel...

    pekonchan 評論0 收藏0
  • 基于 Backbone + node 的個人簡歷生成器(個人學(xué)習(xí)總結(jié))

    摘要:應(yīng)用的功能這個應(yīng)用是一個個人簡歷生成器。比較好的教程有這一個。這樣的命名污染問題自然顯而易見。而且發(fā)出多次請求也會影響性能。明顯不利于維護。然而我希望能夠不發(fā)生變化,因為是在文件的前提下的標(biāo)簽頁,不能換一個標(biāo)簽就重建一個。 為什么學(xué)習(xí)backbone?這是個好問題。在這個前端框架爆炸的年代,比起backbone,對開發(fā)來說有更多更好的選擇,react,vue,angular等等。但這些...

    lansheng228 評論0 收藏0
  • 2017年前端框架、類、工具大比拼

    摘要:相比于開發(fā)人員的數(shù)量,目前框架類庫和工具的數(shù)量似乎更多一些。本文將會討論目前最為流行的客戶端框架類庫和工具以及它們之間的基本差異。典型的類庫包括字符串處理日期元素事件動畫網(wǎng)絡(luò)請求等功能。所以不需要明確的區(qū)分類庫框架和工具。 相比于JavaScript開發(fā)人員的數(shù)量,目前JavaScript框架、類庫和工具的數(shù)量似乎更多一些。截至2017年5月,GitHub上的快速搜索顯示,有超過110...

    Alliot 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<