Vue 是一款国产的非常优秀的前端框架,官方的介绍是: Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的渐进式框架。
今天封装了一个带参数的弹窗方法,可以直接调用,自定义图片,提示文字,取消和确定(带参数的方法)。
首先,我在 components 目录下创建一个 CreditConfirmMask.vue 的文件,用来调用。代码如下:
<template> <div class="am-mask"> <div class="am-content-wrapper"> <img class="am-img" :src="sendMask.img"> <div class="am-caption">{{sendMask.title}}</div> <div class="am-buttom"> <a-button type="primary" @click="confirmMask">确定</a-button> </div> <div class="am-cancel" @click="cancel">取消</div> </div> </div> </template> <script> export default { name: "sendMask", props: ['sendMask'], data () { return {} }, methods: { cancel(){ this.$emit('close'); }, confirmMask() { this.$emit('goto'); }, }, } </script> <style scoped> .am-mask { position: fixed; top: 0; left: 0; bottom: 0; right: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.5); z-index: 5; } .am-content-wrapper { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 450px; padding: 34px 0 20px; background-color: #fff; position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%); border-radius: 10px; } .am-img { width: 350px; } .am-caption { color: #1F2645; font-size: 16px; margin-bottom: 25px; } .am-buttom .ant-btn-primary { margin-top: 0; box-shadow: none; margin-bottom: 25px; } .am-cancel { color: #ACACAC; font-size: 16px; padding-bottom: 5px; border-bottom: 1px solid #ACACAC; cursor: pointer; } </style>
组件的引用:
在 script 标签内引入:
import CreditConfirmMask from "../../components/CreditConfirmMask.vue"
调用该组件:
components: { CreditConfirmMask },
前端引用:
<CreditConfirmMask v-if="isMask" :sendMask="sendMask" @close="cancelMask" @goto="confirmMask(sendMask.id)" />
data:
data: function () { return { isMask: false, sendMask: { img: '', title: '', id: '',//产品id }, } },
方法调起:这时候可以将弹窗图片,提示文字和参数传过去。
maskShow(){ this.isMask = true; this.sendMask.img="../../../static/image/xiajia.png"; this.sendMask.title="是否将上架产品"; this.sendMask.num="1"; },
这个confirmMask()
方法就可以接收到传过来的 id
confirmMask(id){ ... }
组件调用效果:
原创文章,作者:kirin,如若转载,请注明出处:https://blog.ytso.com/231459.html