最近在写 jq 的插件时,尝试这样使用以下的结构,发现无论如何都无法获取到 jquery 的链上传递过来的 this:
//扩展 jq
$.fn.extend({
newFun: {
Fun_A: function(){
console.log(this);
},
Fun_B: function(){
//更多的同级方法
}
}
});
//执行时
$().newFun.Fun_A();
//结果没有拿到$入口的参数
{Fun_A: ƒ}
然而使用以下代码时,则可以获取到这个$('div')传入的参数,
//扩展 jq
$.fn.extend({
newFun: function(){
console.log(this)
}
});
//执行时
$('div').newFun();
//结果拿到了参数
init(3) [div#imgsgls, div#imgs2gls, div, prevObject: init(1), context: document, selector: "div"]
想想也不奇怪,this 本身就是根据环境不断变化的,但我需要$()里面传入的参数 有什么办法能获得吗?是我忽略了手册上的东西,还是说原本 jq 设计就无法获取到这个参数的呢? 因为以前都是直接调用内置的方法,没自己写过扩展,没想到第一次写就遇到困难了。网上也查了资料,似乎没有相关的信息,是我写法太刁钻了吗?菜鸟,汗颜,希望 v 友不吝啬赐教
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.