首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >jQuery每个函数抛出错误: Uncaught :无法读取属性

jQuery每个函数抛出错误: Uncaught :无法读取属性
EN

Stack Overflow用户
提问于 2016-10-27 12:40:04
回答 1查看 447关注 0票数 0

我正在为我的项目创建一个定制的step.js应用程序。我在对象范围上出错了。下面是我的代码

代码语言:javascript
运行
复制
var STEPPED = {
    el: {
        stepContentDiv: $('#stepContent'),
        stepNavDiv:     $('#stepNav'),
        stepNavLi:      $('#stepNav li'),
        stepNavAnchor:  $('#stepNav li a'),
        stepNavDone:  $('#stepNav li a'),
        stepNavActive:  $('#stepNav li a')
    },
    doActive: function(){
        this.el.stepNavDone.on('click', function(){
            this.el.stepNavLi.each(function(){
                alert();
            });
        });
    },
    init: function(){
        this.doActive();
    }
}
STEPPED.init();

当我运行这个时会出错

代码语言:javascript
运行
复制
this.el.stepNavLi.each(function(){
    alert();
});

未定义的TypeError:无法读取未定义的属性“stepNavLi”

有人能帮我吗?这里有什么问题?提前感谢

EN

回答 1

Stack Overflow用户

发布于 2016-10-27 12:44:07

click事件处理程序函数中,this引用的是单击的元素,而不是STEPPED对象。如果要在单击处理程序中保留对对象的引用,则需要将对对象的引用缓存在变量中。试试这个:

代码语言:javascript
运行
复制
doActive: function() {
    var _stepped = this;
    _stepped.el.stepNavDone.on('click', function(){
        _stepped.el.stepNavLi.each(function(){
            alert();
        });
    });
},
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40284829

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档