解決Vue控制臺報錯Failed to mount component: template or render function not defined.
Vue控制臺報錯Failed to mount component: template or render function not defined.
今天vue一直報錯
vue.runtime.esm.js?2b0e:619 [Vue warn]: Failed to mount component: template or render function not defined.
一直以為是引用問題,找了很多解決方案都沒有,到最后解決了記錄一下
我的這個問題的根源在于 vue的文件命名和js的文件命名一致,然后又在同一個文件夾下面,比如下面
Area.vue 和 Area.js在同一個文件夾下面,且同名。
我的解決方案一
是將vue重命名為index.vue
解決方案二
再建一個文件夾專門放js文件,不和vue放在一個文件夾下面。
更改了文件命名后,能正常運(yùn)行了.
Vue控制臺報錯信息收集并上報
自己理解為什么,直接上代碼
import axios from 'axios'; export default class JsReport { private getToken; private prefix: string; constructor(prefix, getToken) { console.log('js reporter init success'); this.getToken = getToken; this.prefix = prefix; } /* * 合并對象,將配置的參數(shù)也一并上報 */ _cloneObj(oldObj) { if (typeof(oldObj) != 'object') return oldObj; if (oldObj == null) return oldObj; var newObj = new Object(); for (var prop in oldObj) newObj[prop] = oldObj[prop]; return newObj; } /** * 擴(kuò)展對象 */ _extendObj() { var args = arguments; if (args.length < 2) {return;} var temp = this._cloneObj(args[0]); //調(diào)用復(fù)制對象方法 for (var n = 1,len=args.length; n <len; n++){ for (var index in args[n]) { temp[index] = args[n][index]; } } return temp; } send(msg: string | Event, url: string, line: number, col: number, error: any) { let defaults = { errMsg: msg, location: url, lineNumber: line, columnNumber: col, errDetail: error, } if (error && error.stack) { defaults.errDetail = error.stack.toString(); } else if (arguments.callee) { let ext = []; let fn = arguments.callee.caller; let floor = 3; while (fn && (--floor > 0)) { ext.push(fn.toString()); if (fn == fn.caller) { break; } fn = fn.caller; } defaults.errDetail = ext.join(","); } let headers = { 'Content-Type': 'application/json', 'Authorization': this.getToken } axios.put( this.prefix + '/log/front/err/log', defaults, { headers } ).then(res => { if (res.status == 200 && res.data.code == 0) { console.log('錯誤上報成功'); } }).catch(err => { }) } };
- 注冊
// apiConfig.baseUrl 為不同環(huán)境下的前綴,如果沒有,空即可 var jsReport = new JsReport(apiConfig.baseUrl, UserProfile.findLoginToken()); // window 的異常步獲被 vue 攔截處理掉了 Vue.config.errorHandler = function( err, vm, info) { console.log('vue 步獲異常 err: ', err); jsReport.send(err.message, window.location.href, 0, 0, err) }
- 查看結(jié)果
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于Vue CSR的微前端實(shí)現(xiàn)方案實(shí)踐
這篇文章主要介紹了基于Vue CSR的微前端實(shí)現(xiàn)方案實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05vue語法自動轉(zhuǎn)typescript(解放雙手)
這篇文章主要介紹了vue語法自動轉(zhuǎn)typescript,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09Vue使用正則校驗(yàn)文本框?yàn)檎麛?shù)
這篇文章主要介紹了Vue使用正則校驗(yàn)文本框?yàn)檎麛?shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10vue點(diǎn)擊Dashboard不同內(nèi)容 跳轉(zhuǎn)到同一表格的實(shí)例
這篇文章主要介紹了vue點(diǎn)擊Dashboard不同內(nèi)容 跳轉(zhuǎn)到同一表格的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11Vue3動態(tài)倒計時的代碼實(shí)現(xiàn)
在使用Vue框架開發(fā)Web應(yīng)用時,倒計時功能是一個常見的需求,它可以在一定時間內(nèi)重復(fù)執(zhí)行某些操作,比如防止用戶重復(fù)提交表單、限制投票次數(shù)、實(shí)現(xiàn)驗(yàn)證碼獲取等功能,所以本文給大家介紹了Vue3動態(tài)倒計時的代碼實(shí)現(xiàn),需要的朋友可以參考下2024-09-09