這篇文章主要講解了“jQuery的設計模式有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“jQuery的設計模式有哪些”吧!
成都創(chuàng)新互聯公司主營棗強網站建設的網絡公司,主營網站建設方案,成都app軟件開發(fā),棗強h5重慶小程序開發(fā)搭建,棗強網站營銷推廣歡迎棗強等地區(qū)企業(yè)咨詢
var eventHub = $({}) eventHub.on('xxx', function(){ console.log('收到') }) eventHub.trigger('xxx')
$.fn.modal = function(){ ... } $('#div1').modal()
Vue 2 的插件也是類似的思路哦
$('div').on('click', 'span', function(){...})
說實話,你在 2018 年找前端讓他寫一個事件委托,我保證 90% 寫出來的代碼都是有「明顯」bug 的。
$('div').text('hi').addClass('red').animate({left: 100})
$(fn) $('div') $(div) $($(div)) $('span', '#scope1')
你會發(fā)現 $ 這個函數的參數可以是函數、字符串、元素和 jQuery 對象,甚至還能接受多個參數,這種重載是怎么做到的?
// 你的插件在一個 button 上綁定了很多事件 $button.on('click.plugin', function(){...}) $button.on('mouseenter.plugin', function(){...}) // 然后你想在某個時刻移除以上所有事件 $button.off('.plugin')
如果你不用 jQuery 就很麻煩了。
var fn2 = $.proxy(fn1, asThis, param1)
$.proxy 接受一個函數,返回一個新的函數。
其他就不一一列舉了。
jQuery 的 API 風格依然在流行
我們把 jQuery 和 Axios 做一下對比:
$.ajax({url:'/api', method:'get'}) $.get('/api').then(fn1,fn2) axios({ url: '/api', method: 'get'}) axios.get('/api').then(fn1, fn2)
為什么 2018 年流行的 axios 跟 jQuery.ajax 這么相像呢?
因為 jQuery 的 API 實在太好用了!搞得新庫根本沒法超越它,沒有辦法設計出更簡潔的 API 了。畢竟 jQuery 也是在前端界流行近十年。
所以你學了 jQuery 很容易過渡其他類似的新庫。
jQuery 也能做 MVC
很多人以為前端框架是從 Vue、React 和 Angular 才開始的,其實 jQuery 時代早就有基于 jQuery 的 MV* 庫了,比如著名的 Backbone.js 和 Marionette.js。
看看下面的 Backbone 應用代碼
var TodoView = Backbone.View.extend({ tagName: 'div', template: _.template($('#item-template').html()), events: { 'click .toggle': 'xxx', }, initialize: function () { this.listenTo(this.model, 'change', this.render); }, render: function () { if (this.model.changed.id !== undefined) {return; } this.$el.html(this.template(this.model.toJSON())); return this; } });
感謝各位的閱讀,以上就是“jQuery的設計模式有哪些”的內容了,經過本文的學習后,相信大家對jQuery的設計模式有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯,小編將為大家推送更多相關知識點的文章,歡迎關注!
本文題目:jQuery的設計模式有哪些
網站網址:http://jinyejixie.com/article26/ppsecg.html
成都網站建設公司_創(chuàng)新互聯,為您提供網站導航、Google、手機網站建設、網站建設、網站制作、動態(tài)網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯