Notice: 函数 WP_Scripts::localize 的调用方法不正确$l10n 参数必须是一个数组。若要将任意数据传递给脚本,请改用 wp_add_inline_script() 函数。 请查阅调试 WordPress来获取更多信息。 (这个消息是在 5.7.0 版本添加的。) in /data/www/appblog/wp-includes/functions.php on line 6131

Vue全局Filter体验

定义全局Filter

src/common/global.js

import Vue from 'vue'

Vue.filter('formatOrderStatus', function (orderStatus) {
  switch (orderStatus) {
    case 'INIT':
      return '订单创建'
    case 'WAITPAY':
      return '等待支付'
    case 'PAYSUCCESS':
      return '支付成功'
    case 'PAYFAILURE':
      return '支付失败'
    default:
      return ''
  }
})

配置webpack

build/webpack.base.conf.js

module.exports = {
  ...
  resolve: {
    extensions: ['.js', '.vue', '.json'],
    alias: {
      'vue$': 'vue/dist/vue.esm.js',
      '@': resolve('src'),
      'Global': path.resolve(__dirname, '../src/common/global.js'),
    }
  },
  ...
  plugins: [
    new webpack.optimize.CommonsChunkPlugin('common.js'),
    new webpack.ProvidePlugin({
      jQuery: "jquery",
      $: "jquery",
      Global: "Global",
    })
  ]
}

使用全局Filter

<template>
  <span>{{ order.orderStatus | formatOrderStatus }}</span>
</template>

<script>
import Global from 'Global' // eslint-disable-line no-unused-vars

export default {
  data () {
    return {
      order: {}
    }
  }
}
上一篇 Vue刷新当前页面或组件
下一篇 Vue自定义组件(简单实现一个自定义组件)