1. 程式人生 > >全端之jquery文件操作

全端之jquery文件操作

一、相關知識點總結
1、CSS
.css()
      - .css("color")  -> 獲取color css值
- .css("color", "#ff0000") -> 設定值
      - .css({"color": "#cccccc", "border": "1px solid #ff0000"})  -> 設定多個值
      - .css(["color", "border"])  -> 獲取多個值
   .offset
       - 獲取相對位置
       - 比較的物件是html (視窗)
   .position
        - 獲取相對已經定位的父標籤的位置
        - 比較的是最近的那個做過定位的祖先標籤
   .scrollTop([val])
      - 返回頂部的例子
   .scrollLeft([val])
   尺寸:
    height([val|fn])
      - 元素的高度
   width([val|fn])
       - 元素的寬度
   innerHeight()
      - 帶padding的高度
   innerWidth()
       - 帶padding的寬度
   outerHeight([soptions])
      - 在innerHeight的基礎上再加border的高度
   outerWidth([options])
       - 在innerHeight的基礎上再加border的高度

2、文件操作


內部插入
    A.append(B)       把B新增到A的後面
    A.appendTo(B)     把A新增到B的後面
    A.prepend(B)      把B新增到A的前面
    A.prependTo(B)    把A新增到B的前面
外部插入
    A.after(B)        把B新增到A的後面
    A.insertAfter(B)  把A新增到B的後面
    A.before(B)     把B新增到A的前面
    A.insertBefore(B) 把A新增到B的前面

    包裹
    wrap(html|ele|fn)
      A.wrap(B)  --> B包A
   unwrap()   不抱
      - 不要加引數

   wrapAll(html|ele)  都包(作為整體包),只包你選中的那個
   wrapInner(html|ele|fn)  裡面包
    替換
    replaceWith(content|fn)
      A.replaceWith(B)  --> B替換A

   replaceAll(selector)
      A.replaceAll(B)   --> A替換B

    刪除
    empty()
      - 清空 內部清空

   remove([expr])
      - 刪除 整體都刪除
   detach([expr])
      - 剪下  多儲存在變數中,方便再次使用
    克隆/複製
    clone([Even[,deepEven]])

3、動畫
基本
   show([s,[e],[fn]])
   hide([s,[e],[fn]])
   toggle([s],[e],[fn])
滑動
   slideDown([s],[e],[fn])
   slideUp([s,[e],[fn]])
   slideToggle([s],[e],[fn])
淡入淡出
   fadeIn([s],[e],[fn])
   fadeOut([s],[e],[fn])

   fadeTo([[s],o,[e],[fn]])
      - 淡出到0.66透明度
   fadeToggle([s,[e],[fn]])
      - .fadeToggle(3000, function () {
            alert("真沒用3");
        });
自定義
animate(p,[s],[e],[fn])1.8*

   - css屬性值都可以設定
    - 圖片變小(漏氣)
4. 事件處理

  之前繫結事件的方式:
      1. onclick=clickMe();  function clickMe() {}
      2. ele.onclick = function(){}
      3. ele.addEventListener("click", function(){})  js事件委派

   jQuery繫結事件的方式:
      1. $(ele).on("click", function(){})
      2. $("tbody").delegate(".btn-warning", "click", function(){})  這個3.幾的版本沒有這個方法了,這是3.幾以前版本有的方法
      3. $("tbody").on("click",".btn-warning",function(){})  jQuery的事件委派

二、圖片詳述

(1)offset 和 postion

三、具體程式碼實現

1、返回首頁

1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <title>返回首頁</title>
  6 </head>
  7 <style>
  8     .c1{
  9         height: 100px;
 10     }
 11     button{
 12         position: fixed;
 13         right: 15px;
 14         bottom: 15px;
 15         background-color: #336699;
 16     }
 17     .hide{
 18         display: none;
 19     }
 20 </style>
 21 
 22 <body>
 23 <div class="c1">1</div>
 24 <div class="c1">2</div>
 25 <div class="c1">3</div>
 26 <div class="c1">4</div>
 27 <div class="c1">5</div>
 28 <div class="c1">6</div>
 29 <div class="c1">7</div>
 30 <div class="c1">8</div>
 31 <div class="c1">9</div>
 32 <div class="c1">10</div>
 33 <div class="c1">11</div>
 34 <div class="c1">12</div>
 35 <div class="c1">13</div>
 36 <div class="c1">14</div>
 37 <div class="c1">15</div>
 38 <div class="c1">16</div>
 39 <div class="c1">17</div>
 40 <div class="c1">18</div>
 41 <div class="c1">19</div>
 42 <div class="c1">20</div>
 43 <div class="c1">21</div>
 44 <div class="c1">22</div>
 45 <div class="c1">23</div>
 46 <div class="c1">24</div>
 47 <div class="c1">25</div>
 48 <div class="c1">26</div>
 49 <div class="c1">27</div>
 50 <div class="c1">28</div>
 51 <div class="c1">29</div>
 52 <div class="c1">30</div>
 53 <div class="c1">31</div>
 54 <div class="c1">32</div>
 55 <div class="c1">33</div>
 56 <div class="c1">34</div>
 57 <div class="c1">35</div>
 58 <div class="c1">36</div>
 59 <div class="c1">37</div>
 60 <div class="c1">38</div>
 61 <div class="c1">39</div>
 62 <div class="c1">40</div>
 63 <div class="c1">41</div>
 64 <div class="c1">42</div>
 65 <div class="c1">43</div>
 66 <div class="c1">44</div>
 67 <div class="c1">45</div>
 68 <div class="c1">46</div>
 69 <div class="c1">47</div>
 70 <div class="c1">48</div>
 71 <div class="c1">49</div>
 72 <div class="c1">50</div>
 73 <div class="c1">51</div>
 74 <div class="c1">52</div>
 75 <div class="c1">53</div>
 76 <div class="c1">54</div>
 77 <div class="c1">55</div>
 78 <div class="c1">56</div>
 79 <div class="c1">57</div>
 80 <div class="c1">58</div>
 81 <div class="c1">59</div>
 82 <div class="c1">60</div>
 83 <div class="c1">61</div>
 84 <div class="c1">62</div>
 85 <div class="c1">63</div>
 86 <div class="c1">64</div>
 87 <div class="c1">65</div>
 88 <div class="c1">66</div>
 89 <div class="c1">67</div>
 90 <div class="c1">68</div>
 91 <div class="c1">69</div>
 92 <div class="c1">70</div>
 93 <div class="c1">71</div>
 94 <div class="c1">72</div>
 95 <div class="c1">73</div>
 96 <div class="c1">74</div>
 97 <div class="c1">75</div>
 98 <div class="c1">76</div>
 99 <div class="c1">77</div>
100 <div class="c1">78</div>
101 <div class="c1">79</div>
102 <div class="c1">80</div>
103 <div class="c1">81</div>
104 <div class="c1">82</div>
105 <div class="c1">83</div>
106 <div class="c1">84</div>
107 <div class="c1">85</div>
108 <div class="c1">86</div>
109 <div class="c1">87</div>
110 <div class="c1">88</div>
111 <div class="c1">89</div>
112 <div class="c1">90</div>
113 <div class="c1">91</div>
114 <div class="c1">92</div>
115 <div class="c1">93</div>
116 <div class="c1">94</div>
117 <div class="c1">95</div>
118 <div class="c1">96</div>
119 <div class="c1">97</div>
120 <div class="c1">98</div>
121 <div class="c1">99</div>
122 <div class="c1">100</div>
123 <button class="hide">返回頂部</button>
124 <button class="cc hide">返回底部</button>
125 <script src="jquery-3.2.1.min.js"></script>
126 <script>
127     $(":button").on("click",function () {
128         $(window).scrollTop(0);// 給一個滾動條位置
129 //        $(window).scrollTop(500)
130     });
131     $(window).scroll(function () {
132         //滾動的時候做的操作
133         if ($(window).scrollTop()>100){
134             $(":button").removeClass("hide")
135         }
136         else{
137             $(":button").addClass("hide")
138         }
139     });
140 
141 </script>
142 </body>
143 </html>
View Code

2、檢視尺寸

1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>尺寸</title>
 6     <style>
 7         .c1{
 8             height: 100px;
 9             width: 80px;
10             background-color: red;
11         }
12     </style>
13 </head>
14 <body>
15 <div class="c1"></div>
16 <script src="jquery-3.2.1.min.js"></script>
17 <script>
18 //  沒設定前
19     console.log($(".c1").height);
20     console.log($(".c1").width);
21     console.log($(".c1").innerHeight()); //100
22 //  設定後   innerHeight()
23     $(".c1").css("padding","20px");
24     console.log($(".c1").innerHeight()); //140(自己的高度+padding(內邊距)
25     console.log($(".c1").innerWidth()); //120(自己的高度+padding(內邊距)
26 
27 //  測試margin
28      $(".c1").css("margin","20px"); //和外邊距沒有關係,高度還是140
29      console.log($(".c1").innerHeight());
30 
31 //  outerHeight()
32     console.log($(".c1").outerHeight()); //140(自己的高度+padding(內邊距)
33     $(".c1").css("border","10px solid yellow")//120(自己的高度+padding(內邊距)
34     console.log($(".c1").outerHeight()); //160(自己的高度+padding(內邊距)+border的寬度
35 
36 //  測試margin
37      $(".c1").css("margin","30px"); //和外邊距沒有關係,高度還是160
38      console.log($(".c1").outerHeight());
39 
40 
41 </script>
42 </body>
43 </html>
View Code

3、CSS示例

1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>css示例</title>
 6 </head>
 7 <style>
 8     .c2{
 9         width: 100px;
10         height: 100px;
11         background-color: red;
12         position: relative;
13         top: 50px;
14         left: 50px;
15     }
16     .c3{
17         width: 100px;
18         height: 100px;
19         background-color: greenyellow;
20         position: absolute;
21         left: 100px;
22         top: 100px;
23 
24     }
25 </style>
26 <body>
27 <div class="c1">你好那?</div>
28 <div class="c4">哎呦歪</div>
29 <div class="c2">
30     <div class="c3"></div>
31 </div>
32 
33 <script src="jquery-3.2.1.min.js"></script>
34 <script>
35 //  1、  .css()
36     $(".c1").css("color","#336699");//找到標籤,設定單個樣式
37     console.log($(".c1").css("color"));//獲取color css值
38     $(".c4").css({"color":"red","border":"1px solid green","font-size":"20px"});//設定多個樣式
39     console.log($(".c4").css(["color","border","font-size"]))
40 //    2、offset
41     console.log($(".c2").offset());
42     console.log($(".c2").offset().left);
43     console.log($(".c2").offset().top);
44 
45     console.log($(".c3").offset()); //{top: 107, left: 58}
46     console.log($(".c3").position());//{top: 100, left: 100}
47 
48 </script>
49 </body>
50 </html>
View Code

4、文件操作

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>文件操作</title>
 6 </head>
 7 <ul id="u1">
 8     <li>111</li>
 9     <li>222</li>
10     <li>333</li>
11     <li>444</li>
12 </ul>
13 <p>蒼茫的大海是我的哎</p>
14 <ul id="u2">
15     <li>第一章</li>
16     <li>第二章</li>
17     <li>第三章</li>
18     <li>第四章</li>
19 </ul>
20 <body>
21 <script src="jquery-3.2.1.min.js"></script>
22 <script>
23 //    在內部插入
24 //      append:往後新增
25     $("#u1").append("<li>456</li>");
26     var li =document.createElement("li");
27     $(li).text(666);
28     $(li).appendTo($("#u1"));
29     $("#u1>li:first").appendTo($("#u1")); //吧第一個新增到這個列表中。注意是挪動,不是複製
30     $("#u1>li:last").appendTo($("#u1"));
31 //      prepend :往前新增
32     $("#u2").prepend("<li>啦啦啦</li>");  //吧啦啦啦新增到列表的前面
33 
34     var tem = document.createElement("li");
35     tem.innerText = "嘩啦啦。呼啦啦";
36     $(tem).prependTo($("#u2")) ;//吧啦啦啦新增到列表裡(先建立)
37 
38 //    在外部插入
39 //    after
40     $("#u2").after("<div>哈啊好好</div>");  //在列表的後面插入
41 
42     var tem = document.createElement("div");
43     $(tem).text("哎哎呀");
44     $(tem).css("color","red");
45     $(tem).insertAfter($("#u2"));  //插入到列表的後面
46 //    before
47     $("#u2").before("<div>111</div>");  //在列表的前面插入
48 
49     var tem = document.createElement("div");
50     $(tem).text("six");
51     $(tem).css("color","blue");
52     $(tem).insertBefore($("#u2"))  //插入到列表的後面
53 
54 //    包裹
55 // wrap和unwrap
56     var tem = document.createElement("div");
57     $(tem).css("border","1px solid #ff0000");
58     $("#u1").wrap($(tem));  //讓tem吧列表包起來
59     $("#u1").unwrap() ;//不包,不需要加引數
60 //    wrapAll和wrap和wrapInner
61     var tem = document.createElement("div");
62     $(tem).css("border","1px solid yellow");
63     $("ul").wrapAll($(tem)); //都包
64     $("ul").wrap($(tem)); //單個包
65     $("ul").wrapInner($(tem));//裡面包
66 
67 //    替換
68 //    replaceWith和replaceAll
69     $("ul").replaceWith("<p>你愁啥?<p>") ;//吧所有的列表替換成你愁啥?
70 
71     var ele = document.createElement("p");
72     $(ele).text("你愁啥?");
73     $(ele).replaceAll($("ul"));
74 
75 //    刪除
76     $("ul:first").empty() ;//吧第一個ul清空
77     $("ul>li:first").empty() ;//只是清空內容
78     $("ul>li:last").remove();//都清空
79 
80       var a = $("#u1>li:first").detach();  //刪除以後還保留著,可以再次使用
81       a.appendTo($("#u1"))
82 </script>
83 </body>
84 </html>
View Code

5、克隆(複製)

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>克隆</title>
 6 </head>
 7 <body>
 8 <button class="c1">點我點我</button>
 9 <script src="jquery-3.2.1.min.js"></script>
10 <script>
11     $(".c1").on("click",function () {
12         $(this).clone(true).insertAfter($(this))
13     })
14 </script>
15 </body>
16 </html>
View Code

6、動畫效果

1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>動畫</title>
 6     <style>
 7         .hide{
 8             display: none;
 9         }
10     </style>
11 </head>
12 <body>
13 <img src="z.png" alt="">
14 <script src="jquery-3.2.1.min.js"></script>
15 <button class="c1">召喚</button>
16 <button class="c2">淡出</button>
17 <button class="c3">淡入</button>
18 <button class="c4">淡出到0.66透明度</button>
19 <button class="c5">淡入淡出</button>
20 <button class="c6">動畫:圖片變小</button>
21 <script>
22     $(".c1").on("click",function () {
23 //        $("img").hide();
24 //        $("img").show();
25         $("img").toggle();
26     });
27 
28 //    淡出
29     $(".c2").on("click",function () {
30         $("img").fadeOut();
31         $("img").fadeOut("fast"); //快速的淡出
32     });
33 //    淡入
34     $(".c3").on("click",function () {
35 //        增加淡入的時間
36         $("img").fadeIn(3000,function () {
37 //            alert(123)
38         });
39     });
40 //    淡出到0.66透明度
41     $(".c4").on("click",function () {
42         $("img").fadeTo(3000,0.66,function () {
43 //            alert(123)
44         })
45     });
46 //    淡入淡出
47     $(".c5").on("click",function () {
48         $("img").fadeToggle(3000,function () {
49 //            alert(123)
50         })
51     })
52 //    動畫-圖片變小
53     $(".c6").on("click",function () {
54         $("img").animate(
55             {
56                 width:"80px",
57                 height:"80px"
58             },3000,function () {
59                 //這是一個回撥函式
60                 alert(123)
61             }
62         )
63     })
64 </script>
65 </body>
66 </html>
View Code