JQuery(笔记)

4 篇文章 0 订阅
1 篇文章 0 订阅

1.jQuery定义

jQuery由美国人John Resig于2006年创建
jQuery是目前最流行的JavaScript程序库,它是对JavaScript对象和函数的封装
它的设计思想是write less,do more

2.为什么使用jQuery?

(1)js实现隔行换色

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8"/>
    <script type="text/javascript">
    window.onload = function(){
        var trs = document.getElementsByTagName("tr");
        for(var i=0;i<trs.length;i++){
            if(i%2==0){
            trs[i].style.background = "red";
            }
        }
    }
    </script>
  </head>
  
  <body>
        <form action="">
            <table>
                <tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>
                <tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
            </table>
        </form>
  </body>
</html>

(2)jQuery实现隔行换色

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8"/>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
    <script type="text/javascript">
        $(function(){
            $("tr:even").css("background","red");
        });
    </script>
  </head>
  
  <body>
        <form action="">
            <table>
                <tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>
                <tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
            </table>
        </form>
  </body>
</html>

3.jQuery语法结构

$(selector).action() ; 
​
工厂函数$():将DOM对象转化为jQuery对象
选择器 selector:获取需要操作的DOM 元素
方法action():jQuery中提供的方法,其中包括绑定事件处理的方法

4.引入jQuery类库

<script src="js/jquery-1.12.4.js" type="text/javascript"></script>

5.jQuery-HelloWorld-实现弹出提示框

<script>
     $(function() {
        alert("我欲奔赴沙场征战jQuery,势必攻克之!");
    });
</script>

6.jQuery应用实战

6.1addClass( )添加样式

<!DOCTYPE html>
<html>
  <head>
   <meta charset="utf-8"/>
    <style type="text/css">
        .h{
            background:red
        }
    </style>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
    <script type="text/javascript">
     $(function(){
        //$("tr:even").addClass("h");
    });
    </script>
  </head>
​
  <body >
        <form action="" >
            <table >
                <tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>
                <tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
            </table>
        </form>
  </body>
</html>

6.2css( )设置样式

<!DOCTYPE html>
<html>
  <head>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
    <script type="text/javascript">
     $(function(){
         $("tr:even").css("background","red");
    });
    </script>
  </head>
​
  <body >
        <form action="" >
            <table >
                <tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>
                <tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
            </table>
        </form>
  </body>
     
</html>
​

6.3show( )、hide( )元素显示和隐藏

<html>
<head>
<meta charset="utf-8"/>
<script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $(".btn1").click(function(){
  $("p").hide();
  });
  $(".btn2").click(function(){
  $("p").show();
  });
});
</script>
</head>
<body>
<p>This is a paragraph.</p>
<button class="btn1">Hide</button>
<button class="btn2">Show</button>
</body>
</html>

6.4next()链式操作

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8"/>
  <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
</head>
​
<body>
<ul>
   <li>list item 1</li>
   <li>list item 2</li>
   <li class="third-item">list item 3</li>
   <li>list item 4</li>
   <li>list item 5</li>
</ul>
​
<script>
$('li.third-item').next().css('background-color', 'red');
</script>
​
</body>
</html>
解析:通过next()方法显示的是当前位置的下一个
​

6.5css({})隐式迭代

 $(function() {
        $("li").css({"font-weight":"bold","color":"red"});
 });
 解析:<因为前面li是一个隐形的数组,所以可以设置多个样式>

案例:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<script src="/jquery/jquery-1.11.1.min.js"></script>
<script>
$(document).ready(function(){
  $("button").click(function(){
    $("p").css({"background-color":"yellow","font-size":"200%"});
  });
});
</script>
</head>
​
<body>
<h2>这是标题</h2>
<p style="background-color:#ff0000">这是一个段落。</p>
<p style="background-color:#00ff00">这是一个段落。</p>
<p style="background-color:#0000ff">这是一个段落。</p>
<p>这是一个段落。</p>
<button>为 p 元素设置多个样式</button>
</body>
</html>

6.6 DOM对象和jQuery对象的转化

(1)DOM对象转为jQuery对象

var txtName =document.getElementById("txtName"); //DOM对象
var $txtName =$(txtName);                        //DOM对象转化为jQuery对象
​

(2)jQuery对象转为DOM对象

第一种方式:

var $txtName =$ ("#txtName"); //jQuery对象
var txtName =$txtName[0];     //DOM对象

第二种方式:

var $txtName =$("#txtName");  //jQuery对象
var txtName =$txtName.get(0); //DOM对象

案例:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8"/>
    <style type="text/css">
        .h{
            background:red
        }
    </style>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
    <script type="text/javascript">
     $(function(){
         var a = $("table").css("background","red");
         //var b = document.getElementById("tr");
         alert(a instanceof jQuery);
    });
    </script>
  </head>
​
  <body >
        <form action="" >
            <table >
                <tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>
                <tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
            </table>
        </form>
  </body>
</html>

7.扩展-初始化函数-$(document).ready()与window.onload的区别

window.onload$(document).ready()
执行时机flash、视频等)才能执行网页中所有DOM文档结构绘制完毕后即刻执行,可能与DOM元素关联的内容(图片、flash、视频等)并没有加载完
编写个数同一页面不能同时编写多个同一页面能同时编写多个
简化写法$(function(){ //执行代码}) ;

案例:

<html>
  <head>
    <meta charset="utf-8"/>
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
    <script type="text/javascript">
        //window.onload = function(){
             //$("tr:eq(1)").css("background","red");
        //}
        //window.onload = function(){alert(1);}
        //window.onload = function(){alert(2);}
        $(function(){alert(3);});
        $(function(){alert(4);});
    </script>
  </head>
​
  <body >
        <form action="" >
            <table >
                <tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>
                <tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
                <tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>
            </table>
        </form>
  </body>
     
</html>

​​

案例2:同一页面能同时编写多个*

<head>

  <meta charset="UTF-8">

  <meta http-equiv="X-UA-Compatible" content="IE=edge">

  <meta name="viewport" content="width=device-width, initial-scale=1.0">

​​

  <script type="text/javascript" src="jquery-1.8.3.min.js"></script>

  <script type="text/javascript">

$(function(){

alert(1);

});

$(function(){

alert(2);

});

</script>

</style>

</head>

<body>

​​​

    

<tr><td>序号</td><td>订单号</td><td>商品名称</td><td>价格</td></tr>

<tr><td>1</td><td>32</td><td>53</td><td>价35</td></tr>

<tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>

<tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>

<tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>

<tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>

<tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>

<tr><td>2</td><td>4</td><td>商品53称</td><td>价53</td></tr>

</table>

</form>

</body>

</html>

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,关于 jQuery 的事件,我可以和你分享一些学习笔记。 1. 绑定事件 在 jQuery 中,我们可以通过以下方式来绑定事件: ``` $(selector).event(function(){ // 事件处理程序 }) ``` 其中,`selector` 表示要绑定事件的元素,`event` 表示要绑定的事件类型,比如 `click`、`mouseover` 等等。事件处理程序则是在事件触发时要执行的代码块。 2. 多个事件绑定 我们可以通过 `on()` 方法来同时绑定多个事件: ``` $(selector).on({ event1: function(){ // 事件处理程序1 }, event2: function(){ // 事件处理程序2 } }) ``` 这样,当 `event1` 或 `event2` 中任意一个事件触发时,对应的处理程序都会被执行。 3. 解除事件 如果需要解除某个元素的事件处理程序,可以使用 `off()` 方法: ``` $(selector).off(event); ``` 其中,`event` 表示要解除的事件类型。如果不指定事件类型,则会解除该元素上所有的事件处理程序。 4. 事件委托 在 jQuery 中,我们可以使用事件委托来提高性能。事件委托是指将事件绑定到父元素上,而不是绑定到子元素上,然后通过事件冒泡来判断是哪个子元素触发了该事件。这样,当子元素数量较多时,只需要绑定一次事件,就可以监听到所有子元素的事件。 ``` $(selector).on(event, childSelector, function(){ // 事件处理程序 }) ``` 其中,`selector` 表示父元素,`event` 表示要绑定的事件类型,`childSelector` 表示要委托的子元素的选择器,事件处理程序则是在子元素触发事件时要执行的代码块。 以上是 jQuery 中事件的一些基本操作,希望对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

代码贩子、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值