一個簡單Widget實例開發
作者:佚名
Widget實例開發是本文要介紹的內容,主要是來了解并學習Widget實例開發,本文內容不多,主要是以代碼來實現內容的詳解,來看詳文。
Widget實例開發是本文要介紹的內容,主要是來了解并學習Widget實例開發,本文內容不多,主要是以代碼來實現內容的詳解,來看詳文。
這里是一個簡單的widget,在代碼里也寫了注釋。
代碼
- //此widget是將textbox進行修飾一下的。自身沒有css,采用的是jquery ui css framework的樣式
- (function($){
- //ui默認采用jquery的ui前綴,后面的是widget名稱
- $.widget("ui.textboxdecorator", {
- //此widget中沒有options
- options:{
- },
- _init: function(){
- //驗證是否是需要裝飾的元素
- if (!(this.element.attr("tagName").toLowerCase() === "input" || this.element.attr("tagName").toLowerCase() === "textarea")) {
- return;
- }
- if (!(this.element.attr("type").toLowerCase() === "text" || this.element.attr("type").toLowerCase() === "password")) {
- if (this.element.attr("tagName").toLowerCase() === "input")
- return;
- }
- //this.element也就是調用此widget的元素
- var e = this.element;
- //ui-widget widget基本的樣式,ui-state-default。默認狀態的樣式;ui- corner-all 圓角(基于css3,ie下不起作用)
- this.element.addClass("ui-widget ui-state-default ui-corner-all");
- //添加hover效果和active效果
- this.element.mouseover(function(){
- e.addClass("ui-state-hover");
- }).mouseout(function(){
- e.removeClass("ui-state-hover");
- }).mousedown(function(){
- e.addClass("ui-state-active");
- }).mouseup(function(){
- e.removeClass("ui-state-active");
- });
- },
- //銷毀時,移除widget增加的樣式
- destroy:function(){
- this.element.removeClass("ui-widget ui-state-default ui-corner-all ui-state-hover ui-state-active");
- }
- })
- })(jQuery)
在使用該widget的時候,需要引用jquery,jquery.ui.core.js,jquery.ui.widget.js文件,css文件需要jquery.ui.core.css和jquery.ui.theme.css兩個文件
在調用的時候采用$("***"). textboxdecorator();來調用此widget。
小結:一個簡單Widget實例開發的內容介紹完了,希望通過Widget實例開發內容的學習能對你有所幫助!
責任編輯:zhaolei
來源:
博客園