繁体   English   中英

调用匿名函数javascript

[英]call anonymous function javascript

我需要调用函数传递参数。 这是我的代码。

 var myfb; var MyFaceBook = function(response) { this.response = response; }; MyFaceBook.prototype.dd = function(_array) { console.log(_array); } MyFaceBook.prototype.doLike = function(_url) { this.dd(_url); return false; } MyFaceBook.prototype.getTabList = function() { return '<a href="#" onclick="'+this.doLike.call('http://facebook.com')+'"> Like </a> | <a href="#">Share</a> | <a href="#"> Comment </a>'; }; myfb = new MyFaceBook(response = array()); myfb.getTabList(); 

我真正需要的是,当我单击“赞”按钮时,我需要管理所传递的网址,即“ facebook.com”。

您不需要使用callthis.doLike.call(...) )来调用函数,只需执行this.doLike(...)

 var myfb; var MyFaceBook = function(response) { this.response = response; }; MyFaceBook.prototype.dd = function(_array) { console.log(_array); } MyFaceBook.prototype.doLike = function(_url) { this.dd(_url); return false; } MyFaceBook.prototype.getTabList = function() { return '<a href="#" onclick="myfb.doLike(\\'http://facebook.com\\')"> Like </a> | <a href="#">Share</a> | <a href="#"> Comment </a>'; }; myfb = new MyFaceBook([]); document.body.innerHTML += myfb.getTabList(); 

这不是执行此操作的最佳方法。 您应该使用document.createElement创建链接,将事件侦听器附加到它们EventTarget#addEventListener ,然后使用Node#appendChild将这些链接附加到DOM

 const MyFaceBook = function(response) { this.response = response; }; MyFaceBook.prototype.dd = function(_array) { console.log(_array); } MyFaceBook.prototype.doLike = function(_url) { this.dd(_url); return false; } MyFaceBook.prototype.getTabList = function() { const link = document.createElement('a'); link.innerHTML = 'Like'; link.addEventListener("click", () => { this.doLike('http://facebook.com'); }); document.body.appendChild(link); }; const myfb = new MyFaceBook([]); myfb.getTabList(); 

我同意@ ponury-kostek的回答,以及下面的代码行

myfb = new MyFaceBook(response = array());

你可以用

myfb = new MyFaceBook("your response here");

如果是数组:

myfb = new MyFaceBook(["your response here","another response..."]);

这是一个完整的可执行代码,可以正常工作:

 var myfb; var MyFaceBook = function(response) { this.response = response; }; MyFaceBook.prototype.dd = function(_array) { console.log(_array); } MyFaceBook.prototype.doLike = function(_url) { this.dd(_url); return false; } MyFaceBook.prototype.getTabList = function() { return '<a href="#" onclick="'+this.doLike('http://facebook.com')+'"> Like </a> | <a href="#">Share</a> | <a href="#"> Comment </a>'; }; myfb = new MyFaceBook(["my response"]); myfb.getTabList(); 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM