zoukankan      html  css  js  c++  java
  • jQuery自定义插件 安静点

    我们可以扩展jquery,自定义方法,在使用的时候可以直接调用
    需求:
     1. 给 $ 添加4个工具方法:
       * min(a, b) : 返回较小的值
       * max(c, d) : 返回较大的值
       * leftTrim() : 去掉字符串左边的空格
       * rightTrim() : 去掉字符串右边的空格
     2. 给jQuery对象 添加3个功能方法:
     * checkAll() : 全选
     * unCheckAll() : 全不选
     * reverseCheck() : 全反选
    my_jQuery-plugin.js:
    /*
     需求:
     1. 给 $ 添加4个工具方法:
       * min(a, b) : 返回较小的值
       * max(c, d) : 返回较大的值
       * leftTrim() : 去掉字符串左边的空格
       * rightTrim() : 去掉字符串右边的空格
     2. 给jQuery对象 添加3个功能方法:
     * checkAll() : 全选
     * unCheckAll() : 全不选
     * reverseCheck() : 全反选
     */
    (function () {
    
      // 扩展$的方法
      $.extend({
        min: function (a, b) {
          return a < b ? a : b
        },
        max: function (a, b) {
          return a > b ? a : b
        },
        leftTrim: function (str) {
          return str.replace(/^\s+/, '')
        },
        rightTrim: function (str) {
          return str.replace(/\s+$/, '')
        }
      })
    
      // 扩展jQuery对象的方法
      $.fn.extend({
        checkAll: function () {
          this.prop('checked', true) // this是jQuery对象
        },
        unCheckAll: function () {
          this.prop('checked', false)
        },
        reverseCheck: function () {
          // this是jQuery对象
          this.each(function () {
            // this是dom元素
            this.checked = !this.checked
          })
        }
      })
    
    })()

    使用:

    <!DOCTYPE html>
    <html>
    <head>
      <meta charset="UTF-8"> 
      <style type="text/css">
        * {
          margin: 0px;
        }
    
        .div1 {
          position: absolute;
          width: 100px;
          height: 100px;
          top: 50px;
          left: 10px;
          background: red;
        }
      </style>
    </head>
    <body>
    <input type="checkbox" name="items" value="足球"/>足球
    <input type="checkbox" name="items" value="篮球"/>篮球
    <input type="checkbox" name="items" value="羽毛球"/>羽毛球
    <input type="checkbox" name="items" value="乒乓球"/>乒乓球
    <br/>
    <input type="button" id="checkedAllBtn" value="全 选"/>
    <input type="button" id="checkedNoBtn" value="全不选"/>
    <input type="button" id="reverseCheckedBtn" value="反选"/>
    
    <!--
    1. 扩展jQuery的工具方法
      $.extend(object)
    2. 扩展jQuery对象的方法
      $.fn.extend(object)
    -->
    <script src="js/jquery-1.10.1.js" type="text/javascript"></script>
    <script type="text/javascript" src="js/my_jQuery-plugin.js"></script>
    <script type="text/javascript">
      /*
       需求:
       1. 给 $ 添加4个工具方法:
         * min(a, b) : 返回较小的值
         * max(c, d) : 返回较大的值
         * leftTrim() : 去掉字符串左边的空格
         * rightTrim() : 去掉字符串右边的空格
       2. 给jQuery对象 添加3个功能方法:
         * checkAll() : 全选
         * unCheckAll() : 全不选
         * reverseCheck() : 全反选
       */
      console.log($.min(3, 5), $.max(3, 5))
      var string = '   my atguigu    '
      console.log('-----' + $.leftTrim(string) + '-----')
      console.log('-----' + $.rightTrim(string) + '-----')
    
      //$items为jquery的对象
      var $items = $(':checkbox[name=items]')
      $('#checkedAllBtn').click(function () {
        $items.checkAll()
      })
      $('#checkedNoBtn').click(function () {
        $items.unCheckAll()
      })
      $('#reverseCheckedBtn').click(function () {
        $items.reverseCheck()
      })
    </script>
    </body>
    </html>
  • 相关阅读:
    crazyflie2.0 RCC时钟知识
    quick-cocos2d-x开发工具sublime text及其强力插件QuickXDev
    [Swift通天遁地]一、超级工具-(16)使用JTAppleCalendar制作美观的日历
    [Swift]LeetCode186. 翻转字符串中的单词 II $ Reverse Words in a String II
    [SQL]LeetCode185. 部门工资前三高的员工 | Department Top Three Salaries
    [Swift通天遁地]一、超级工具-(15)使用SCLAlertView制作强大的Alert警告窗口和Input编辑窗口
    [SQL]LeetCode184. 部门工资最高的员工 | Department Highest Salary
    [Swift通天遁地]一、超级工具-(14)使用SweetAlert制作漂亮的自定义Alert窗口
    [Swift]关键字:Self、self与super
    [Swift]LeetCode964. 表示数字的最少运算符 | Least Operators to Express Number
  • 原文地址:https://www.cnblogs.com/anjingdian/p/15600566.html
Copyright © 2011-2022 走看看