手机QQ浏览器不支持vue.js对象参数缩写

最近正要用vue.js写个页面,非模块化开发,直接在页面script引入vue.js和vue-router.js,在 chrome 显示好好的,小米自带的浏览器也是正常的,然后到了手机QQ浏览器就出问题了。

官方文档:https://router.vuejs.org/zh-c...

官方示例修改

html

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>

<div id="app">
  <h1>Hello App!</h1>
  <p>
    <!-- 使用 router-link 组件来导航. -->
    <!-- 通过传入 `to` 属性指定链接. -->
    <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
    <router-link to="/foo">Go to Foo</router-link>
    <router-link to="/bar">Go to Bar</router-link>
  </p>
  <!-- 路由出口 -->
  <!-- 路由匹配到的组件将渲染在这里 -->
  <router-view></router-view>
</div>
<script type="text/template" id="foo">
    <div class="">这里是foo</div>
</script>
<script type="text/template" id="bar">
    <div class="">这里是bar</div>
</script>

javascript

// 1. 定义(路由)组件。
// 这里把 template 放到了 html 里去,用 script 标签存放着,调用的时候用 #{id},.{class}我没试过,不知道行不行
const Foo = { template: '#foo' };
const Bar = { template: '#bar' };

// 2. 定义路由
// 从上一个就应该开始注意了,const 语句后面要加分号“;”
const routes = [
  { path: '/foo', component: Foo },
  { path: '/bar', component: Bar }
];

// 3. 创建 router 实例,然后传 `routes` 配置
// 你还可以传别的配置参数, 不过先这么简单着吧。
const router = new VueRouter({
  routes: routes // 官方文档写着可以用缩写形式只写 routes,然后在手Q浏览器是不行的,必须 key: value 的形式存在。
})

// 4. 创建和挂载根实例。
// 记得要通过 router 配置参数注入路由,
// 从而让整个应用都有路由功能
const app = new Vue({
  router: router    // 这里同样是必须 key: value 形式,不然运行不起来
}).$mount('#app');

// 现在,应用已经启动了!

在 html 里写模板

使用 const Foo = { template: '<div>foo</div>' } 这种在 script 里写模板 html 很不方便,特别是内容比较多的时候,遇到换行还会报错,要行全写一行,要么是用 + 号连接起来。

也是在 vuejs的组件中该如何引用一个html模板而不是片段? 上看到 @dososo 指点的方法,果然很赞!

经过上面的一番改造,终于可以兼容手Q浏览器了~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值