vue不支持ie6;vue官方聲明是支持ie8以上版本的。不支持原因:1、ie8及以下版本不支持“Object.defineProperty”方法,但該方法是vue實(shí)現(xiàn)響應(yīng)式的所必須的;2、Vue需要Promise的支持,而IE8及以下版本不支持Promsie。
本教程操作環(huán)境:windows7系統(tǒng)、vue3版,DELL G3電腦。
在從Vue官網(wǎng)可以看出:Vue是不支持IE6的。
Vue 不支持 IE8 及以下版本,因?yàn)?Vue 使用了 IE8及以下版本 無(wú)法模擬的 ECMAScript 5 特性。但它支持所有兼容 ECMAScript 5 的瀏覽器。
例如:
-
Vue.js會(huì)對(duì)所有的實(shí)現(xiàn)雙向綁定的數(shù)據(jù),使用 Object.defineProperty 把這些屬性全部轉(zhuǎn)為 getter/setter。Object.defineProperty 是 ES5 中一個(gè)無(wú)法 shim 的特性,這也就是為什么 Vue 不支持 IE8 以及更低版本瀏覽器的原因。
注意這里:Object.defineProperty是無(wú)法通過墊板實(shí)現(xiàn)的一個(gè)方法,是和瀏覽器自身有關(guān)系的,所以Vue從根本上來(lái)說本來(lái)就無(wú)法支持IE8;
-
Vue需要Promise的支持,IE8及以下版本同樣不支持Promsie。
擴(kuò)展資料:
Object.defineProperty()
該方法允許精確添加或修改對(duì)象的屬性。一般情況下,我們?yōu)閷?duì)象添加屬性是通過賦值來(lái)創(chuàng)建并顯示在屬性枚舉中(for…in 或 Object.keys 方法),但這種方式添加的屬性值可以被改變,也可以被刪除。而使用 Object.defineProperty() 則允許改變這些額外細(xì)節(jié)的默認(rèn)設(shè)置。例如,默認(rèn)情況下,使用 Object.defineProperty() 增加的屬性值是不可改變的。
在 vue 源碼中搜索 “Object.defineProperty” :
可以看到有 5 個(gè)匹配的地方,也就是說 vue 中有 5 處使用了 “Object.defineProperty()”。
搜索的版本是: Vue.js v1.0.26
Object.defineProperty()的瀏覽器支持情況:
可以看出支持情況是 IE9 及以上。
【