vue-router解決相同路徑跳轉報錯的問題
vue-router解決相同路徑跳轉報錯
剛寫完一個vue的項目,現在總結和記錄下項目中遇到的問題,加強自己,並且分享給你們。
昨天也看瞭一下項目,忘記記錄,今天還在看項目,就記錄下。
今天看到路由的時候,看到下面這句代碼,不知道什麼作用瞭
VueRouter.prototype.push = function push(location) { return routerPush.call(this, location).catch(error=> error) }
註釋之後才想起來,進相同的路徑會報錯,加上這句代碼後,就會不會報錯瞭。順便說一嘴,就是進入相同的路徑不會刷新數據,我用的方法是監聽我們項目的環節num,隻要這個改變,就重選請求數據。
大致意思就是監聽一個會改變的變量,重新請求數據才會刷新數據。
這個問題,當時做項目的時候貌似查瞭很久,希望可以幫助到你。
vue常見錯誤解決
1.運行vue時瀏覽器報錯Unknown custom element: <custom-select> – did you register the component correctly? For recursive components, make sure to provide the "name" option
原因:被引用的組件頁面沒有進行export,導致尋找不到瀏覽器console報錯,但是編譯的時候沒有語法問題不報錯
解決:
方法1: export { default as AppMain } from './AppMain'
方法2:將vue/dist/vue.esm.js註銷,修改為vue/dist/vue.min.js
2.vue router 報錯Uncaught (in promise) NavigationDuplicated {_name:""NavigationDuplicated"… 的解決方法
router-link 會造成報錯的問題, 報錯內容為:
(1)解決方法很簡單,把項目依賴的 node_modules 文件夾刪除, 然後再 npm install 重新下載依賴包就可以解決
(2)發現以上方法很多人都不能成功解決,經過多次嘗試發現原因可能是 在重新下載依賴包時,安裝的vue-router還是之前出錯的那個版本,那麼要怎麼解決呢?解決方法也很簡單,在項目目錄下運行 npm i [email protected] -S 即可
(3)在main.js下添加一下代碼:
import Router from 'vue-router' const originalPush = Router.prototype.push Router.prototype.push = function push(location) { return originalPush.call(this, location).catch(err => err) }
3.Vue報錯 [Vue warn]: Property or method "name" is not defined on the instance but referenced…..
原因:在data中沒有定義一個name, 致錯
解決方法:在data中定義一個name=" ",
[Vue warn]: Property or method "value" is not defined on the instance but referenced…..
原因:template中定義瞭屬性,如v-model,但在data中沒有定義一個value
解決方法:在data中定義一個value=" ",
4.Error in render: "TypeError: Cannot read property ‘list’ of undefined"
**報錯:**渲染錯誤:“未定義的Type Error:無法讀取屬性”列表
**原因:**沒給list定義,也就是說在temple中用到list瞭,但是在data中沒定義這個字段,如果已經定義瞭但是還是報錯,請檢查下自己是否拼錯瞭單詞,因為我就是這麼蠢瞭= =
解決:
data () { return { list: [] } },
5.[Vue warn]: Property or method “message” is not defined on the instance but referenced during render. Make sure that this property is reactive, either in the data option, or for class-based components, by initializing the property
報錯:message沒定義
原因:跟上面的一樣,message在data那裡沒有定義,定義一個初始值就好
解決:
data() { return { message: '' } },
6.Module build failed: Error: No parser and no file path given, couldn’t infer a parser.
報錯:沒有語法分析器和文件路徑,無法推斷解析器
原因:依賴包出現問題,prettier 一個vue-cli的依賴,把一個feature 的移除當作次版本發佈
解決:npm install –save-dev [email protected](刪除 node_modules下[email protected]@prettier文件夾)
7.routes forEach is not a function
原因:forEach routes沒有發現裡面有值
解決:
1.查看import {routes} from './routes’這個路徑是否正確
2.routes是一個數組,檢查routes是否是一個數組
3.是否已經new瞭一個router,又再次new一遍?
// main.js // 路由配置 const RouterConfig = { // 使用HTML5的History模式 mode: 'history', routes: Routers } // new VueRouter const router = new VueRouter(RouterConfig) // router.js // 在router中又再次new一遍,重復瞭!!!! export default new Router({ routes: [ { path: '/', name: 'home', component: home } ] })
改為:
// router.js const routers = [ { path: '/home', meta: { title: '主頁' }, component: (resolve) => require(['../page/home.vue'], resolve) ] export default routers
8.[Vue warn]: Unknown custom element: – did you register the component correctly? For recursive components, make sure to provide the “name” option.
原因:被引用的組件頁面沒有進行export,導致尋找不到瀏覽器console報錯,但是編譯的時候沒有語法問題不報錯
解決:
export { default as AppMain } from './AppMain'
9.TypeError: Cannot read property ‘vue’ of undefined
報錯信息:ERROR in ./src/login.vue Module build failed (from ./node_modules/[email protected]@vue-loader/index.js): TypeError: Cannot read property ‘vue’ of undefined at Object.module.exports (F:\VistualStudioCode\threess\[email protected]@vue-loader\lib\load er.js:61:18) @ ./src/main.js 7:13-35 @ multi ./node_modules/[email protected]@webpack-dev-server/client?http://localhost:3000 (webpack)/h ot/dev-server.js ./src/main.js
原因:vue-loader這個插件被破壞瞭
解決:
// 重新安裝依賴 npm install vue-loader@latest --save-dev
總結
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- vue3配置router路由並實現頁面跳轉功能
- vue3.x項目降級到vue2.7的解決方案
- vue3使用vue-router的完整步驟記錄
- Vue-router路由該如何使用
- Vue路由vue-router詳細講解指南