Maison > Article > interface Web > vue crée un composant bouton
Cette fois, je vais vous montrer comment créer un composant bouton avec Vue. Quelles sont les précautions à prendre pour créer un composant bouton avec Vue. Ce qui suit est un cas pratique, jetons un coup d'oeil.
Solution :
Communication via des composants parent-enfant ($refs et props)
props accepte les paramètres, $refs appels La méthode du sous-composant
est utilisée pour changer l'état du bouton en cliquant sur Soumettre. En cas d'échec, l'état du bouton est annulé
<template> <!-- use plane --> <!-- 传入bgColor改变按钮背景色 --> <!-- state切换button的状态 调用cancel()可以切换 --> <!-- text为按钮文字 --> <p class="container"> <button @click="confirm" :disabled="state" class="confirm" :style="{background: btnData.bgColor}" >{{text}}</button> </p> </template> <script> export default { data(){ return { text: this.btnData.text, state: false, } }, props: { btnData: { types: Array, default() { return { text: '确认', } } } }, methods: { confirm(){ this.text += '...' this.state = true //这里是激活父组件的事件,因为子组件是不会冒泡到父组件上的,必须手动调用$emit //相对应父组件要在调用该组件的时候,将其挂载到上面 this.$emit("confirm") }, cancel(){ this.text = this.btnData.text this.state = false } } } </script> <style lang="less" scoped> .confirm { border: none; color: #fff; width: 100%; padding: 1rem 0; border-radius: 4px; font-size: 1.6rem; background: #5da1fd; &:focus { outline: none; } } </style>est appelé dans la page :
<template> <p class="btn-box"> <Btn :btnData="{text: '确认注册'}" <!--这里就要挂载$emit调用的事件 @confirm="想要调用事件的名字"--> @confirm="confirm" ref="btn" ></Btn> </p> </template> <script> import Btn from '@/components/button' export default { components: { Btn }, methods: { confirm(){ if(!this.companyName){ this.$toast("公司名不能为空") this.$refs.btn.cancel() } } } </script>Ici, faites attention à quelques détails : 1. Une fois le composant bouton formé, l'espacement entre celui-ci et les autres éléments p est difficile à réutiliser s'il est fixé à l'intérieur du composant.
Retournez à la page d'accueil après avoir partagé la page de développement de l'applet
Utilisez el expression pour juger si c'est le cas vide
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!