zoukankan      html  css  js  c++  java
  • Make jQuery throw error when it doesn't match an element

    Make jQuery throw error when it doesn't match an element

    解答1

    You could make a plugin to use to ensure that the jQuery object is not empty:

    $.fn.ensure = function() {
      if (this.length === 0) throw "Empty jQuery result."
      return this;
    }

    Usage:

    $('ul.some-list').ensure().append(listItem);

    解答2

    In my case, I wanted it automatically applied to everything, so I modified the jQuery constructor. I suggest you only use this during development to catch mistakes, but keep it out of your production so as not to confuse others. As it's not an error, I've just used console logging. However I've added a commented out throw in case you would rather use that:

    var jQueryInit = $.fn.init;
    
    $.fn.init = function(arg1, arg2, rootjQuery) {
        var element = new jQueryInit(arg1, arg2, rootjQuery);
        if (arg1 && element.length === 0) {
            console.log(arg1 +" doesn't exist");
            // throw arg1 +" doesn't exist"
        }
        return element;
    };

    I really wish there was an option in jQuery for turning this on during dev.

    In case anybody is wondering... having the selector return a result set, when there are no valid matches, is a deliberate decision by the developers of jQuery. It means you can apply some code to a collection of elements, even if there is a possibility of there being none. A good example is comments on a page, or checked checkboxes. If it threw an error when there were no were elements found, then you would have to add checks for existence to your code. The following topic has more info: https://stackoverflow.com/a/3709823/109561

    This is great feature for keeping production code lean. However it can really bite you in the ass while developing if you make a small typo; or if you try selecting an ID named "foobar" when you should be selecting a class called "foobar".

  • 相关阅读:
    DDL、DML、TCL
    SQL简介
    Java基础--常用API--IO流相关API
    Java基础--多线程
    Java基础--常用API--集合类相关API
    Java基础--常用API--日期相关API
    Java基础--常用API--字符串相关API
    Java基础--正则表达式的规则
    Java基础--常用API--java.lang.Object
    26、springboot——整合JPA
  • 原文地址:https://www.cnblogs.com/chucklu/p/11131024.html
Copyright © 2011-2022 走看看