讓jquery validation plugin 支援zepto

來源:互聯網
上載者:User

讓jquery validation plugin 支援zepto

做移動端快一年了,一直糾結移動端是用zepto還是用jquery,移動端一直傾向於使用zepto,無奈zepto相關外掛程式太少了,為了讓jquery外掛程式支援zepto不得不修改外掛程式的原始碼。今天我給大家展示的是如何讓jquery.validate.js支援zepto庫。

1、替換不相容的選取器 a、將$.data(selector,dataname)改成$(selector).data(dataname); b、將:submit,:reset,:image,:text 改成[type='submit'],[type='image'],type='text']2、因為jquery和zepto擷取不存在屬性返回的值不一樣,導致Number(value)返回的值也不一樣,這個會導致mix..、max..驗證不能去掉;

找到以下代碼

if (/min|max/.test(method) && (type === null || /number|range|text/.test(type))) {    value = Number(value);}

替換成

if (/min|max/.test(method) && (type === null || /number|range|text/.test(type))) {    value = (value === null || value === ) ? undefined : value;    value = Number(value);}
3、替換$.validator.format方法
// http://jqueryvalidation.org/jQuery.validator.format/$.validator.format = function (source, params) {    if (arguments.length === 1) {        return function () {            var args = [].slice.call(arguments[0])//$.makeArray(arguments);            args.unshift(source);            return $.validator.format.apply(this, args);        };    }    if (arguments.length > 2 && params.constructor !== Array) {        params = [].slice.call(arguments).slice(1);//$.makeArray(arguments).slice(1);    }    if (params.constructor !== Array) {        params = [params];    }    console.log(params);    $.each(params, function (i, n) {        source = source.replace(new RegExp(\{ + i + \}, g), function () {            return n;        });    });    return source;};
4、修複remote方法,將ajax改為同步,即添加async:false 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.