成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

輕量級的DOM操作庫 -- zBase 庫 使用介紹

renweihub / 2795人閱讀

摘要:是我個人寫的一個輕量級的操作庫,里面封裝了一些對元素節(jié)點的簡單操作,如節(jié)點的查詢獲取,的添加移除,樣式的添加移除,節(jié)點的添加和移除,事件的封裝,動畫的封裝等等如果你只是想簡單的操作,但又不想寫繁瑣的原生代碼,也不希望加載像這么功能齊全的庫,

zBase是我個人寫的一個輕量級的 DOM 操作庫,里面封裝了一些對元素節(jié)點的簡單操作, 如節(jié)點的查詢獲取,className的添加移除,樣式的添加移除, 節(jié)點的添加和移除,事件的封裝,動畫的封裝等等...

如果你只是想簡單的操作 dom ,但又不想 寫繁瑣的 js 原生代碼,也不希望加載像 jquery 這么功能齊全的庫,那么 zBase適合你 ?。?!

當然只是做了簡單的封裝,減少 原生 js 操作dom 的麻煩,整個類庫也是利用 $ 操作符,如果在使用的過程中和一些 大型的類庫 如 jquery 沖突可以下載 zBase 源碼,將 $ 改成任意字符即可。

庫的簡單使用:

一、節(jié)點的查找

1、一般查找:

語法 概述
$("div_id") id = "div_id" 的元素
$("p") 所有 p 標簽的元素
$(".className") 所有 class = "className" 的元素
$(this) 當前 HTML 元素

2、組合查找

在此前提下,你還可以任意組合,得到你所需要的節(jié)點,如:

語法 概述
$("div_id p") id = "div_id" 節(jié)點下的 所有 p 元素(注意中間空格)
$(".name1 .name2") 所有class = "name1 " 下的所有 class = "name1 "元素
$("p a") 所有 p 標簽下的 a 標簽元素

3、find查找

利用 find() 方法來查找:

語法 概述
$("p").find("a") 所有 p 標簽下的 a 標簽元素
$(".name1").find(".name2") 所有class = "name1 " 下的所有 class = "name1 "元素
$("#div_1").find("div_2") 注意這樣也是行的,但沒什么意義,最后得到的是 id= "div_2" 的元素,與 id= "div_1"沒關系
二 、操作節(jié)點

由于 $() 及幾乎所有庫的方法都返回當前對象,所以支持鏈式操作

1、.addClass()

//給 所有 p 標簽 添加 一個"name_1"  的className
$("p").addClass("name_1")  
//添加多個  className
$("p").addClass("name_1 name_2")  

2、.removeClass()

//給 所有 p 標簽 移除 一個"name_1"  的className
$("p").removeClass("name_1")  
//移除多個  removeClass
$("p").removeClass("name_1 name_2")  

3、獲取第幾個節(jié)點 .getE()
注意,.getE() 返回的是 dom元素,所以后面不能再執(zhí)行鏈式操作

//得到 ul 里面的 第 3 個 li節(jié)點
$("ul li").getE(2)  

4、獲取第幾個節(jié)點 .getElement()
與第 3 條不同的是 .getElement() 返回的是 當前對象,所以后面可以再執(zhí)行鏈式操作

//得到 ul 里面的 第 3 個 li節(jié)點
$("ul li").getElement(2) .css("color","red"); 

5、操作樣式 .css()

// 給所有 p 標簽 添加 color :red ;樣式
 $("p").css("color","red");
// 給所有 p 標簽 添加多組樣式,參數(shù)是一個 obj
 $("p").css({
        "color":"red",
        "background":"blue"
    });

說明

// 當 參數(shù)為 string 時 ,是 獲取  p 標簽下的 color 樣式,返回一個 rgb(x, x, x)值
 $("p").css("color");

6、獲取 或 設置 某一節(jié)點的屬性 .arrt()

// 給所有 p 標簽 添加 age 屬性
$("p").arrt("age","233");

// 當參數(shù)只有一個時 , 獲得 p 標簽下的屬性
$("p").arrt("age");

7、獲取或設置 .html()

// 給所有 p 標簽 設置 html
$("p").html("我的天,我的地,先賺一個億!?。?!");

// 得到 html 值
$("p").html("age");
三、事件操作

1、隱藏標簽 .show 和 .hide

 
$("p").show();

$("p").hide();

2、鼠標的移入移出事件 .hover();

// hover傳遞兩個函數(shù),分別 用于處理 鼠標移入事件 和 鼠標移出 事件

 $("span").hover(function () {
        $("span").css("color","red");
    },function () {
        $("span") .css("color","blue");
    });

3、添加事件 addEvent(ele,type,fun);
這里做了兼容 IE6、7、8
參數(shù):ele:添加事件的元素節(jié)點 , type:事件類型(click,movie等),fun:執(zhí)行事件函數(shù)
注意:第一個參數(shù)為元素節(jié)點,可用上面提到的 getE() 來獲得

 
 addEvent($("#div_id").getE(0),"click",function () {
        alert(" 啊 ,我被點擊啦~~~ ");
    });

4、移除事件 removeEvent(ele,type,fun)

//添加事件
 addEvent($("#div_id").getE(0),"click",f_click);
// 移除事件
 removeEvent($("#div_id").getE(0),"click",f_click);
 
 function f_click() {
    alert(" 啊 ,我被點擊啦~~~ ");
 }

5、綁定事件 bind();

其實這個方法是有上面的添加事件封裝的,只不過這個方法可以多個元素同時綁定。

// 給所有的 span 標簽 綁定點擊事件

 $("span").bind("click",function () {
        console.log("........"+this);  //  ....[object HTMLSpanElement]
    });
四、動畫

動畫做的不多,就一個 animate() ,其實現(xiàn)在的css3的動畫效果已經(jīng)很強大和簡便了,這里 做了一個動畫的簡單封裝,有興趣可以查看源碼,看一下思路。

animate(obj);
參數(shù)為一個 對象

/
 * @param attr 樣式 ,一般是 left 或 top
 * @param start 開始的位置
 * @param step 移動的距離
 * @param target 移動的終點
 * @param t 每次移動的毫秒
/
    $("#div_id").animate({
        "attr":"x",
        "start":100,
        "t":500,
        "step":10,
        "alter":550
    });
五、一些工具方法

1、設置元素處在 視口中間位置 .centerInWindow()

傳遞的兩個參數(shù)分別是 元素自身的 的 寬 和 高;

// 傳遞的兩個參數(shù)分別是 元素自身的 的 寬 和 高;
 $("#div_id").centerInWindow(100,100);

2、獲取當前視口的大小 getInner();
返回 obj ,兼容 IE

  console.log("...width....."+ getInner().width);
  console.log("...height....."+ getInner().height);

3、獲取 瀏覽器滾動條的距離 getScroll()

 console.log("...top....."+  getScroll().top);
console.log("...top....."+  getScroll().left);

4、圖片預加載 preprocessorImage(obj)
一般呢,我們往 而圖片 預加載 則是 先在后臺請求數(shù)據(jù)加載完圖片,然后再讓圖片一下顯示出來,效果是不同的!
參數(shù) obj :一個對象,里面是 圖片的 鏈接數(shù)組 和 回調函數(shù),如下例子:
加載完圖片,再將

 preprocessorImage({
                img_array:["http://img.pconline.com.cn/images/upload/upc/tx/wallpaper/1209/10/c1/13764273_1347270360314_800x600.jpg",
                    "https://cloud.githubusercontent.com/assets/15622519/18378764/61d0b4be-76a1-11e6-9571-36d785a35e56.png"],
               
                callback:function (img_src) {
                   
                    $("#img-div").html( "");
                }
            });
六、添加插件

在 zBase庫中還支持擴展插件:
比如有個 js 插件

// 加載在 zBase.js 的后面

那么這個js插件需要 用 $().extend("name",fun) 來擴展
參數(shù):第一個參數(shù)為 插件的名稱,第二個參數(shù)是 插件的實現(xiàn)函數(shù)

$().extend("drag",function () {

        // 開始編程...
}

那怎么調用寫好的插件呢? 比如我上面寫了是一個 盒子拖拽的插件,那么我直接調用

 $("#div_id").drag();

此時,id = div_id 的元素就有了拖拽的功能了(前提這個 div 必須 position: absolute;)
關于 zBase_drag.js 插件源碼可以查看的到。

有了插件擴展是不是很方便呢,可以為 zBase 庫 擴展跟多自己實用的功能。

七、ajax封裝

導入 js

ajax(obj);
參數(shù) obj 里面的屬性說明:

 
  method : 請求方式 -- get 或 post
  url : 請求路徑
  async :true 為異步請求 , false 為同步請求
  data : 請求數(shù)據(jù) ,為 一個 對象
  success :請求成功回調函數(shù)
  error :請求失敗回調函數(shù)
 
 addEvent(document,"click",function () {
        ajax({
            method:"get",
            url:"https://api.github.com/users/ZengTianShengZ",
            async:true,
            data:{
                "name":"zeng",
                "age": 24
            },
            success:function (text) {
                alert(text);
            },
            error : function(error_status,error_statusText){
                alert(error_status + "........." + error_statusText);
            }

        });

沒錯,就是怎么使用,是不是很方便,具體可查看源碼

項目有不足的地方歡迎大家 issues ,本類庫適合做一些小項目時使用,主要避免了原生js操作dom的麻煩,但是遠不及jquery,zepto那么強大 的功能。
項目地址 github .................... 歡迎 star

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/80313.html

相關文章

  • Vue學習日記(一)——Vue介紹

    摘要:的核心庫只關注視圖層,并且非常容易學習,非常容易與其它庫或已有項目整合。的目標是通過盡可能簡單的實現(xiàn)響應的數(shù)據(jù)綁定和組合的視圖組件。并不是框架,只是和他旁邊的生態(tài)環(huán)境組成了一個框架,下面,貼一個官方的漸進式框架介紹圖吧,方便理解。 前言 本人學習了一段時間的vue,并嘗試寫了一些小Demo之后,將vue投入了幾個項目之后,一直在邊學習邊使用,經(jīng)過看了vue,vuex,vue-route...

    王晗 評論0 收藏0
  • Vue學習日記(一)——Vue介紹

    摘要:的核心庫只關注視圖層,并且非常容易學習,非常容易與其它庫或已有項目整合。的目標是通過盡可能簡單的實現(xiàn)響應的數(shù)據(jù)綁定和組合的視圖組件。并不是框架,只是和他旁邊的生態(tài)環(huán)境組成了一個框架,下面,貼一個官方的漸進式框架介紹圖吧,方便理解。 前言 本人學習了一段時間的vue,并嘗試寫了一些小Demo之后,將vue投入了幾個項目之后,一直在邊學習邊使用,經(jīng)過看了vue,vuex,vue-route...

    MasonEast 評論0 收藏0
  • javascript功能插件大集合 前端常用插件 js常用插件

    摘要:轉載來源包管理器管理著庫,并提供讀取和打包它們的工具。能構建更好應用的客戶端包管理器。一個整合和的最佳思想,使開發(fā)者能快速方便地組織和編寫前端代碼的下一代包管理器。很棒的組件集合。隱秘地使用和用戶數(shù)據(jù)。 轉載來源:https://github.com/jobbole/aw... 包管理器管理著 javascript 庫,并提供讀取和打包它們的工具。?npm – npm 是 javasc...

    netmou 評論0 收藏0
  • javascript功能插件大集合 前端常用插件 js常用插件

    摘要:轉載來源包管理器管理著庫,并提供讀取和打包它們的工具。能構建更好應用的客戶端包管理器。一個整合和的最佳思想,使開發(fā)者能快速方便地組織和編寫前端代碼的下一代包管理器。很棒的組件集合。隱秘地使用和用戶數(shù)據(jù)。 轉載來源:https://github.com/jobbole/aw... 包管理器管理著 javascript 庫,并提供讀取和打包它們的工具。?npm – npm 是 javasc...

    Hydrogen 評論0 收藏0
  • javascript功能插件大集合,寫前端親們記得收藏

    摘要:一個專注于瀏覽器端和兼容的包管理器。一個整合和的最佳思想,使開發(fā)者能快速方便地組織和編寫前端代碼的下一代包管理器。完全插件化的工具,能在中識別和記錄模式。健壯的優(yōu)雅且功能豐富的模板引擎。完整的經(jīng)過充分測試和記錄數(shù)據(jù)結構的庫。 【導讀】:GitHub 上有一個 Awesome – XXX 系列的資源整理。awesome-javascript 是 sorrycc 發(fā)起維護的 JS 資源列表...

    cfanr 評論0 收藏0

發(fā)表評論

0條評論

renweihub

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<