2017-05-27 194 views
0

在下面的代碼中,當單擊該按鈕時出現錯誤:TypeError: i.Print is not a function。這個錯誤的原因是什麼,我該如何解決?當我查看按鈕的click處理程序中的i的值時,使用Firefox調試器,我看到i.prototype.Print的值爲Outer/Inner.prototype.Print()如何解決函數原型上的'不是函數'錯誤?

<!DOCTYPE html> 
 
    <html lang="en"> 
 
     <head> 
 
      <meta charset="utf-8"> 
 
     </head> 
 
     <body> 
 
      <p id="prn">Value here</p> 
 
      <button id='btn'>Print</button> 
 

 
      <script src="https://code.jquery.com/jquery-1.12.4.min.js"> 
 
      </script> 
 
      
 
      <script> 
 
       function TestObject(i) 
 
       { 
 
        $("#btn").on("click", function() { 
 
         i.Print(); 
 
         i.Change(Math.random() * 10 + 5); 
 
        }); 
 
       } 
 

 
       function TestPrototype() 
 
       { 
 
        var o = function Outer() { 
 
         function Inner(v) 
 
         { 
 
          var iv = v; 
 

 
          function print() 
 
          { 
 
           $("#prn").text(iv); 
 
          } 
 
         }; 
 

 
         Inner.prototype.Print = function() { 
 
          print(); 
 
          console.log(iv); 
 
         }; 
 

 
         Inner.prototype.Change = function(nv) { 
 
          iv = nv; 
 
         }; 
 

 
         return { 
 
          getInner : function(v) { 
 
           var i = Inner; 
 
           i(v); 
 
           return i; 
 
          } 
 
         }; 
 
        }(); 
 

 
        var i1 = o.getInner(10); 
 

 
        TestObject(i1); 
 
       } 
 

 
       ;(function() { 
 
        TestPrototype(); 
 
       }()); 
 
      </script> 
 

 
     </body> 
 
    </html>

回答

2

您需要使用構造函數創建一個對象,

<!DOCTYPE html> 
 
    <html lang="en"> 
 
     <head> 
 
      <meta charset="utf-8"> 
 
     </head> 
 
     <body> 
 
      <p id="prn">Value here</p> 
 
      <button id='btn'>Print</button> 
 

 
      <script src="https://code.jquery.com/jquery-1.12.4.min.js"> 
 
      </script> 
 
      
 
      <script> 
 
       function TestObject(i) 
 
       { 
 
        $("#btn").on("click", function() { 
 
         i.Print(); 
 
         i.Change(Math.random() * 10 + 5); 
 
        }); 
 
       } 
 

 
       function TestPrototype() 
 
       { 
 
        var o = function Outer() { 
 
         function Inner(v) 
 
         { 
 
          // instatiate member variables 
 
          this.iv = v; 
 
          this.print = print; 
 
          
 
          function print() 
 
          { 
 
           $("#prn").text(this.iv); 
 
          } 
 
         }; 
 

 
         Inner.prototype.Print = function() { 
 
          // access member variable 
 
          console.log(this.iv); 
 
          this.print(); 
 
          print(); 
 
         }; 
 

 
         Inner.prototype.Change = function(nv){ 
 
          iv = nv; 
 
         }; 
 

 
         return { 
 
          getInner : function(v) { 
 
           var i = Inner; 
 
           return new i(v); 
 
          } 
 
         }; 
 
        }(); 
 

 
        var i1 = o.getInner(10); 
 

 
        TestObject(i1); 
 
       } 
 

 
       ;(function() { 
 
        TestPrototype(); 
 
       }()); 
 
      </script> 
 

 
     </body> 
 
    </html>

+0

這解決了問題。但是現在,'Inner'對象的私有方法'print'和成員變量'iv'不能從它的'Print'方法訪問。 –

+0

我編輯了我的答案,使用成員變量可以解決這個問題。您可以在日誌中看到輸出。即_console.log_ –

+0

是的,工作。因此對'prototype'函數的需求是可用的,即對象應該使用'new'關鍵字創建? –

相關問題