+
95
-

回答

可以用vue-html-loader,也可以用vue2-sfc-loader,下面我们以vue2-sfc-loader来示例怎么写一个在浏览器直接运行vue文件的方法代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">

</head>
<body>
<div id="app"></div>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/vue@2.6.1.js"></script>
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/vue2-sfc-loader.js"></script>
<script type="module">

/* <!-- */
const mainComponent = `
<template>
<span @click="sayhi">{{title}} from Vue {{ require('myData').vueVersion }} !</span>
</template>
<script>
export default {
data() {
return {
title: 'Hello'
}
},

methods: {
sayhi:function(){
alert("hello");
}
}
}
</script>
`;
/* --> */

const {
loadModule,
vueVersion
} = window['vue2-sfc-loader'];

const options = {
moduleCache: {
vue: Vue,
myData: {
vueVersion,
}
},
getFile(url) {

if (url === '/main.vue')
return Promise.resolve(mainComponent);
},
addStyle() {
/* unused here */
},
}

loadModule('/main.vue', options)
.then(component => new Vue(component).$mount('#app'));
</script>
</body>
</html>


网友回复

我知道答案,我要回答