为什么我的JQuery返回init [0]长度为0?

时间:2017-10-12 11:59:49

标签: javascript jquery html debugging

这是我的第一个jquery,我正在编写一个教程后面的代码(不是jquery教程,所以没有帮助解决这个问题)但是想要了解更多的内容,因为有很多新的层。原始代码由babel重写,因此我不确定是否是因为新标准使得此代码在现代浏览器中不起作用:

原始代码:

import $ from 'jquery';

class MobileMenu{
    constructor() {
        this.menuIcon = $(".site-header__menu-icon");
        this.menuContent = $("site-header__menu-content");
        this.events();
    }

    events() {
        this.menuIcon.click(this.toggleTheMenu.bind(this));
    }

    toggleTheMenu() {
        console.log(this.menuContent);
        this.menuContent.toggleClass("site-header__menu-content--is-visible");
    }

}



export default MobileMenu;

Babel创建了代码:

var MobileMenu = function () {
   function MobileMenu() {
     _classCallCheck(this, MobileMenu);

    this.menuIcon = (0, _jquery2.default)(".site-header__menu-icon");
    this.menuContent = (0, _jquery2.default)("site-header__menu-content");
    this.events();
}

_createClass(MobileMenu, [{
    key: "events",
    value: function events() {
        this.menuIcon.click(this.toggleTheMenu.bind(this));
    }
}, {
    key: "toggleTheMenu",
    value: function toggleTheMenu() {
        console.log(this.menuContent);
        this.menuContent.toggleClass("site-header__menu-content--is-visible");
    }
}]);

return MobileMenu;
}();

exports.default = MobileMenu;

它返回:

[prevObject: jQuery.fn.init(1)]
length:0
prevObject:[document]
__proto__:Object(0)

而不是我想要对其执行操作的预期类。

下面是包含该类的html片段,我在名称中检查了拼写错误,当我搜索jQuery返回init(1)和length:0时为什么没有找到非常有用的信息。我发现:Why is my JQuery selector returning a n.fn.init[0], and what is it?但它看起来非常具体,我希望得到更多的一般信息。我没做动态页面加载。从那个问题我收集到我的jquery返回一个空的结果对象。这是一个正确的理解,我应该在调试中首先检查什么?我在chrome调试器中设置了一个断点,但仍然得到了对象,但是在数组中有两个元素,第一个元素是我单击的对象以触发jquery。

    <div class="site-header__menu-icon"></div>
    <div class="wrapper site-header__menu-content">
      <a href="#" class="btn site-header__btn">Get in Touch</a>
      <nav class="primary-nav primary-nav--pull-right">
        <ul>
          <li><a href="#our-beginning">Our Beginning</a></li>
          <li><a href="#features">Features</a></li>
          <li><a href="#testimonials">Testimonials</a></li>
        </ul>
      </nav>
    </div>
</div>

这是babel模块:

module: {
    loaders: [
        {
            loader: 'babel-loader',
            query: {
                presets: ['es2015']
            },
            test: /\.js$/,
            exclude: /node_modules/
        }
    ]
}

2 个答案:

答案 0 :(得分:1)

jQuery选择器无法识别$(“site-header__menu-content”)。 '。'需要使用前缀来引用您在$(“。site-header__menu-icon”)上使用的类。

对id使用#前缀,。类的前缀,没有元素类型的前缀,如div,img,p等。

答案 1 :(得分:0)

正如Satpal所说,我错过了一个。在我的班级选择器。 jquery的新手应该参考: https://api.jquery.com/category/selectors/ 在他们的特定查询上找到快速答案。