最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - prototype method is not a function,why? - Stack Overflow

programmeradmin1浏览0评论
(function(){
  test();
}());

function Class(){
  this.prop = 'hi';
}
Class.prototype.mod = function(num){this.prop = num;}

function test(){
  var c = new Class();
  c.mod('now'); // it'll say it's not a function
  alert(c.prop); // it's work
}

I wanna move function and class out to ready function to make code clean up and save memory, but I found the class method does not work.

If I moved prototype to test function, it work, like

(function(){
  test();
}());

function Class(){
  this.prop = 'hi';
}


function test(){
  Class.prototype.mod = function(num){this.prop = num;}
  var c = new Class();
  c.mod('now'); // it's ok
  alert(c.prop); 
}

why I must to move prototype method to test or ready function?

(function(){
  test();
}());

function Class(){
  this.prop = 'hi';
}
Class.prototype.mod = function(num){this.prop = num;}

function test(){
  var c = new Class();
  c.mod('now'); // it'll say it's not a function
  alert(c.prop); // it's work
}

I wanna move function and class out to ready function to make code clean up and save memory, but I found the class method does not work.

If I moved prototype to test function, it work, like

(function(){
  test();
}());

function Class(){
  this.prop = 'hi';
}


function test(){
  Class.prototype.mod = function(num){this.prop = num;}
  var c = new Class();
  c.mod('now'); // it's ok
  alert(c.prop); 
}

why I must to move prototype method to test or ready function?

Share Improve this question asked Jan 22, 2015 at 22:46 RoyRoy 7613 gold badges11 silver badges24 bronze badges 2
  • 1 The fact that you call it "ready function" seems to suggest you think the self-executing function ((function(){...}())) waits for the page to load before executing, which is not true. – JJJ Commented Jan 22, 2015 at 22:49
  • as you say, it's self-executing function and I make this js script bottom of page, like ready. is it good to make everything in self-executing function I wanna know, thx – Roy Commented Jan 23, 2015 at 2:07
Add a ment  | 

1 Answer 1

Reset to default 5

Because your .prototype.mod definition is after the function that calls it. Hoisting only helps for the function definition itself (which is why new Class() works fine), not for prototype definitions.

This really shouldn't be so hard: prepare your tools first, then use them.

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论