为什么vue-router和Vuex不能在vue之外的生态使用呢?
大家都知道路由模式有Hash和History两种。在vue-router中也存在这两种,比如过hash模式下可以通过hashchange的方法监听路由是否改变,一旦改变在Vue中会记录变化,利用Vue的响应式机制,拿到与路由规则匹配的组件进行渲染。History提供的方法中pushState,replaceState,popstate也可以监听路由变化。 废话不多说直接上代码。
手写Vue—Router
data:image/s3,"s3://crabby-images/f61ee/f61eeb85b784c573549bf688c06698e8d0557fca" alt=""
data:image/s3,"s3://crabby-images/0d89f/0d89fb58a5825da2fa202c2b6e3424937102a4e6" alt=""
data:image/s3,"s3://crabby-images/5624e/5624efc47987cb09e909a14d38f6ef5b78358f3c" alt=""
所以在Vue-router和Vue是强耦合的,要使用Vue的响应式。
相同的情况下Vuex也是同理
data:image/s3,"s3://crabby-images/84b99/84b994de2c38cde0dbdfa695d49ca7ae327907b3" alt=""
data:image/s3,"s3://crabby-images/51beb/51bebb70d837771f1d2b04e8f0a359f925e6ec7b" alt=""
data:image/s3,"s3://crabby-images/51cf1/51cf19063c11fc632fd9870e4597b59b031d6287" alt=""
Vuex其实也是使用了Vue的响应式,在data中的数据Vue会自动把数据改为响应式数据,
总结: Vue-Router和Vuex需要Vue的响应式系统进行数据的响应式处理进行变更。所以Vue-Router和Vuex不能在Vue生态外使用
网友评论