无码视频在线观看,99人妻,国产午夜视频,久久久久国产一级毛片高清版新婚

  • 億恩科技有限公司旗下門戶資訊平臺!
    服務(wù)器租用 4元建網(wǎng)站

    服務(wù)器端生成的 JavaScript 響應(yīng)

    Russian Doll-caching, Turbolinks 和 SJR的融合簡直就是一杯難以置信的給力雞尾酒。它可以創(chuàng)造出快速的,現(xiàn)代化的,而且非常優(yōu)美的代碼類的網(wǎng)絡(luò)應(yīng)用,好好享用吧!

    Basecamp中的大多數(shù)Ajax操作都是在處理服務(wù)器生成的JavaScript響應(yīng)(SJR)。它的工作原理是這樣的:

    表單通過一種XMLHttpRequest驅(qū)動的形式提交。服務(wù)器創(chuàng)建或更新模型對象。服務(wù)器生成包含了針對該模型對象的更新了的HTML模板的一個(gè)JavaScript響應(yīng)??蛻魜碓u估處理由服務(wù)器返回的JavaScript,然后會更新DOM。

    這種簡單的模式有一些重要的優(yōu)勢:

    1.重用模版而不影響性能

    無論是第一次渲染和隨后的模版更新,你都可以重用模版.如果使用Rails,有一部分技術(shù)像郵件/信息用于這兩種情況。

    如果你只返回JSON格式的信息,你得用你的模版將展示這些信息兩次(一次是服務(wù)器端的第一次回應(yīng),一次是客戶端隨后的更新)—除非你做一個(gè)單一面頁的JavaScript app,這個(gè)app的第一次回應(yīng)是用JSON/客戶端生成方式。

    后面那種方式會很慢,因?yàn)橐日麄€(gè)的Javascript庫load完并在客戶端生成好模版你才能看到效果(這是Twitter早期所用的方式,但隨后被背棄)。但至少在某些情況下這是一個(gè)合理的選擇而且不需要多個(gè)模版。

    2.客戶端需要更少的計(jì)算性能

    雖然嵌入HTML模板的JavaScript可能造成響應(yīng)數(shù)據(jù)量比JSON格式的響應(yīng)要多(盡管用gzip壓縮后幾乎可以忽略),但是這不需要客戶端去做很多的運(yùn)算來更新頁面。

    這意味著,從端到端的觀點(diǎn)出發(fā),處理 JavaScript+HTML的響應(yīng)數(shù)據(jù)的速度,應(yīng)該比處理帶有客戶端模板性質(zhì)的JSON數(shù)據(jù)要快,至于快多少,取決于客戶端模板的復(fù)雜程度,以及客戶端計(jì)算性能。而且這個(gè)速度應(yīng)該是二倍關(guān)系,因?yàn)?,服?wù)器生成的模板可以通過緩存在多個(gè)用戶之間共享(詳見 Russian Doll緩存)。

    3.容易跟蹤執(zhí)行流

    使用SJR會讓跟蹤執(zhí)行流變得非常容易。請求的機(jī)制是標(biāo)準(zhǔn)化的,是會帶有輔助邏輯“l(fā)ikeform_for @post, remote: true”. 當(dāng)然沒有必要對于每個(gè)動作都帶上輔助邏輯。 接著控制器會以渲染完整視圖的方式來渲染響應(yīng)中的部分視圖,其中的目標(biāo)只能是JavaScript 而不是完全的HTML

    完整示例

    1)首先使用消息模板

    <h1>All messages:</h1>

    <%# renders messages/_message.html.erb %>

    <%= render @messages %>

    2) 以Ajax方式提交表單

    <% form_for @project.messages.new, remote: true do |form| %>

      ...

      <%= form.submit "Send message" %>

    <% end %>

    3) 服務(wù)器創(chuàng)建模型對象

    class MessagesController < ActionController::Base

      def create

        @message = @project.messages.create!(message_params)

        respond_to do |format|

          format.html { redirect_to @message } # no js fallback

          format.js   # just renders messages/create.js.erb

        end

      end

    end

    4) 服務(wù)器產(chǎn)生內(nèi)嵌入HTML的JavaScript響應(yīng)

    <%# renders messages/_message.html.erb %>

    $('#messages').prepend('<%=j render @message %>');

    $('#<%= dom_id @message %>').highlight();

    最后評估響應(yīng)工作是由form_for產(chǎn)生的XMLHttpRequest-powered表單來自動處理的。視圖因此由于新消息而更新,此外新消息也通過JS/CSS動畫高亮顯示。

    超越RJS

    當(dāng)我們一開始使用SJR時(shí)我們將它和一個(gè)叫做RJS的前身一起使用,使用RJS你需要寫Ruby模板,然后再將它們轉(zhuǎn)變成JavaScript。它是Coffeescript(或Opalrb,如果你喜歡的話)的簡化版,它錯(cuò)誤地讓許多人舍棄了SJR模式。

    現(xiàn)在我們不使用RJS了(更迭的原因通常很簡單——優(yōu)勢不是那么大,只有極少數(shù)情況下才需要的沒有必要那么復(fù)雜),但我們卻一如既往地致力于SJR。

    這并不意味著JSON數(shù)據(jù)在服務(wù)器端產(chǎn)生和視圖在客戶端形成的模式一無是處。對于我們的UI需要很高的保真度的時(shí)候,以及像日歷這樣的,有大量的視圖狀態(tài)需要維護(hù)的時(shí)候,這樣的模式還是非常合適的。當(dāng)需要走這條路的時(shí)候,我們使用Sam的卓越 Eco template system (認(rèn)為ERB對于CoffeeScript).

    如果你的網(wǎng)絡(luò)應(yīng)用都是高保真度的UI,那么走上面提到的那個(gè)路子是完全沒有問題的。只是你正在花費(fèi)高價(jià)給自己購買些花哨的東西,不過這算是個(gè)問題。但是如果你的應(yīng)用有點(diǎn)像Basecamp或者Github這樣網(wǎng)絡(luò)上的以文本為基礎(chǔ)的主流應(yīng)用,那么你完全應(yīng)該張開雙臂擁抱SJR。

    河南億恩科技股份有限公司(mszdt.com)始創(chuàng)于2000年,專注服務(wù)器托管租用,是國家工信部認(rèn)定的綜合電信服務(wù)運(yùn)營商。億恩為近五十萬的用戶提供服務(wù)器托管、服務(wù)器租用、機(jī)柜租用、云服務(wù)器、網(wǎng)站建設(shè)、網(wǎng)站托管等網(wǎng)絡(luò)基礎(chǔ)服務(wù),另有網(wǎng)總管、名片俠網(wǎng)絡(luò)推廣服務(wù),使得客戶不斷的獲得更大的收益。
    服務(wù)器/云主機(jī) 24小時(shí)售后服務(wù)電話:0371-60135900
    虛擬主機(jī)/智能建站 24小時(shí)售后服務(wù)電話:0371-55621053
    網(wǎng)絡(luò)版權(quán)侵權(quán)舉報(bào)電話:0371-60135995
    服務(wù)熱線:0371-60135900

    標(biāo)簽 服務(wù)器JavaScript
    1
    0
    分享到:責(zé)任編輯:阿柳

    相關(guān)推介

    共有:2條評論網(wǎng)友評論:

    驗(yàn)證碼 看不清換一張 換一張

    親,還沒評論呢!速度搶沙發(fā)吧!