nuxt.js项目中如何添加和使用全局变量
分类:计算机 | 前端 | Vue | SSR服务端渲染 | Nuxt.js框架 | 综合 3565
更新:2020-11-01 09:57:49编辑
在nuxt.js项目中有时候我们需要添加一些全局变量来使用,例如通过一个全局变量配置后台服务地址,这样在所有页面中都可以用到这个后台服务地址了,下面介绍一下在nuxt.js项目中如何添加和使用全局变量。
1 首先新建一个目录config,里面新建一个文件config.vue,内容如下
<script>
const serverurl="http://8.8.8.8:8888/warName";
export default {
serverurl
}
</script>
这里的serverurl就是一个全局变量,用来配置项目的后台服务地址。
2 然后在plugins目录下建立一个文件main.js,内容如下
import Vue from 'vue' // vue 文件引入 - 方便在vue方法内容直接 this 调取
import Globe from '../config/config.vue' // 自定变量内容 其他自便
let main = {
install(Vue) {
Vue.prototype.$globe = Globe; // 变量的内容 后期可以在vue中 this->$globe.xxx 使用
}
};
Vue.use(main); // 这里不能丢
// 这里是 为了在 asyncData 方法中使用
export default ({ app }, inject) => {
// Set the function directly on the context.app object
app.$globe = Globe // 名称
}
3 在nuxt.config.js中配置plugins/main.js,配置如下
module.exports = {
// ... 其他配置
plugins: [
{src: '~/plugins/main', ssr: true}
],
// ... 其他配置
}
4 使用全局变量
经过上面的配置以后我们就可以在nuxt.js项目的任何一个页面中使用我们定义好的全局变量了,使用示例如下:
for (var i = 0; i < this.midimgs[index].imgs.length; i++) {
var imgurl =
this.$globe.serverurl + "/articleimgs/" + this.midimgs[index].imgs[i]; //云服务器
filelist.push({
name: this.midimgs[index].imgs[i],
url: imgurl,
});
}
就是说在任何一个页面我们都可以通过this.$globe.serverurl的形式来使用我们定义的全局变量serverurl。
猿导航
阅读排行榜
- 1vue和el-table使用经验-如何刷新表格数据10318
- 2three.js加载3D瓦片和3dtiles数据生成交互式地图的开源项目8960
- 3Microsoft Visual C++ Redistributable是什么,有什么作用?6287
- 4uni-app使用经验—vue页面和html页面如何互相调用接口并传参4936
- 5mybatis使用经验——mybatis-spring-boot-starter和mybatis的版本对应关系表(持续更新~)4697
- 6Spring学习经验—@ResponseBody注解的使用说明4358
- 7Druid异常解决经验—java.sql.SQLException url not set3960
- 8如何用批处理命令(bat脚本)启动和停止windows服务3636
- 9nuxt.js项目中如何添加和使用全局变量3565
- 10Intellij IDEA下的版本控制VCS的启用与关闭3557
- 11解决SpringBoot使用maven下载不了jar包的问题3040
- 12linux中解压tar.gz文件报错“gzip: stdin: invalid compressed data--format violated”2833
- 13nuxtjs asyncData使用经验—如何发起多个axios请求并携带参数2830
- 14在Nuxt.js项目的head中引用外部js文件2667
- 15在NVIDIA控制面板设置参数时提示“拒绝访问 无法应用选定的设置到您的系统”的解决方法之一2577