我是 Nuxt 框架的新手,我想将材料设计库集成到我的项目中(官方:https ://material.io/develop/web/ )。
我用这个内容制作了一个插件:
import Vue from "vue"
import mdcAutoInit from "@material/auto-init"
import { MDCTextField } from "@material/textfield"
import { MDCTextFieldIcon } from "@material/textfield/icon"
import { MDCSelect } from "@material/select"
import { MDCFormField } from "@material/form-field"
import { MDCRadio } from "@material/radio"
function init() {
/** Select */
mdcAutoInit.register("select", MDCSelect)
/** TextField */
mdcAutoInit.register("textfield", MDCTextField)
mdcAutoInit.register("textfieldIcon", MDCTextFieldIcon)
/** Radio */
mdcAutoInit.register("formfield", MDCFormField)
mdcAutoInit.register("radio", MDCRadio)
// /** Auto Init */
mdcAutoInit.apply()
}
const plugin = {
install(vm) {
console.log("Installing")
vm.component(MDCTextFieldIcon)
vm.component(MDCTextField)
vm.component(MDCSelect)
vm.component(MDCFormField)
vm.component(MDCRadio)
init()
}
}
if (typeof window !== "undefined" && window.Vue) {
window.Vue.use(plugin)
} else {
Vue.use(plugin)
}
我已将其添加到 nuxt.config.js 的插件部分。
它似乎在我加载页面时起作用(例如,文本字段动画正在工作)但是当我使用 nuxt-link 更改页面时,文本字段未初始化。
有谁知道如何让材料设计为每个加载的组件加载初始化函数?
提前致谢 !