疑惑: 在原型方法中访问var变量

 如下代码:
期待结果:  输出 1,2
实际结果:  输出 2,2

<script>

    function A(par)
    {
        var i = par ;
        A.prototype.getI = function ()
        {
            return i ;
        }

    }

    function B()
    {
        var a1 = new A(1);
        var a2 = new A(2);

        console.log(a1.getI());
        console.log(a2.getI());
    }

    B() ;

</script>





如下两种措施能够达到目的
1.  将  【var i = par ;】      改为   【this.i = par ;】
2.  将  【A.prototype.getI = function ()】      改为   【this.getI = function ()】

》疑惑
本问题的本质是js作用域(上下文空间)。
请朋友们指点迷津

prototype放构造函数外,要不没次构造都会更新prototype中getI函数执行最后一次构造的传入的参数了

要么就不要prototype,直接this.getI=...生成新方法


    function A(par) {
        var i = par;
        this.getI = function () {
            return i;
        }

    }
    //或者===>
    function A(par) { this.i = par }
    A.prototype.getI = function () { return this.i}

http://cnodejs.org/topic/5056e007433135ca35034e8d

谢谢楼上2位的回答。
我想知道原因,请朋友们针对问题作出解释

图片说明
主要原因: A的原型什么getI方法只有一个,不会因为你多次new而增加,而是后面new的时候原型上面的getI方法被覆盖。你代码中是先new 两次,
这时候A原型什么的getI方法时第二次new的那个,这时,getI方法能拿到的i是2.
如果是第一次new的时候,先console,就输出1,再new再输出,就是2
针对解决方法:
方法一: 构造函数在new的时候,new关键字干了两件事,一个就是创建一个对象,然后将对象的__proto__指向构造函数A的prototype,
这时,构造函数中的this指向的是新创建的对象,this.i就是创建时传入的值,所以能够拿到1
方法二:原理同方法一,只是换成了函数