您好,登錄后才能下訂單哦!
這篇文章主要講解了“jQuery的設計模式有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“jQuery的設計模式有哪些”吧!
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')
你會發現 $ 這個函數的參數可以是函數、字符串、元素和 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的設計模式有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。