<template> <div class="demo-list"> <lc-title title="弹框"></lc-title> <category title="基本用法"></category> <div> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog1"> <span slot="title"> <label>自定义标题和内容</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog2"> <span slot="title"> <label>只有标题</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog3"> <span slot="title"> <label>只有内容</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog4"> <span slot="title"> <label>移除按钮栏</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog5"> <span slot="title"> <label>事件</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog6"> <span slot="title"> <label>无弹出动效</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog7"> <span slot="title"> <label>遮罩层透明</label> </span> </lc-cell> </div>
<category title="图片弹窗"></category> <p>type值为“image”时为图片弹窗,需要配置一张图片,可带链接(非必须)。默认展示关闭按钮。点击图片触发onClickImageLink事件,返回false可阻止默认的跳转链接行为。</p> <div> <lc-cell :isLink="true" :showIcon="true" @click.native="showImageDialog"> <span slot="title"> <label>图片弹窗</label> </span> </lc-cell> </div>
<category title="背景滚动锁定"></category> <p>lockBgScroll值设为true时,可在弹窗出现时锁定页面滚动,且不影响窗体内部滚动。</p> <div> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog8"> <span slot="title"> <label>背景滚动锁定</label> </span> </lc-cell> <lc-cell :isLink="true" :showIcon="true" @click.native="showDialog9"> <span slot="title"> <label>窗体内部滚动不影响页面滚动</label> </span> </lc-cell> </div>
<category title="高级用法"></category> <p>如果Dialog内容有复杂交互,可使用Dialog的标签式用法。</p> <div> <lc-cell :isLink="true" :showIcon="true" @click.native="dialogShow=true"> <span slot="title"> <label>以标签形式调用Dialog</label> </span> </lc-cell> </div> <lc-dialog title="标签形式调用" :visible="dialogShow" @ok-btn-click="dialogShow=false" @cancel-btn-click="dialogShow=false" @close="dialogShow=false"> <a href="javascript:;" @click="dialogShow=false" :noCancelBtn="true">点我可以直接关闭对话框</a> </lc-dialog>
<lc-actionsheet :is-visible="isEditor" > <div slot="custom"> <lc-cell title="选择货品" :showIcon="true" :isLink="true" @click.native="isItem=true"> <div slot="desc" class="selected-option">{{item.name!='' ? item.name : '请选择'}}</div> </lc-cell> <lc-cell :isLink="true" > <div slot="title" class="selected-option"> <lc-textinput v-model="item.num" :hasBorder="false" placeholder="请输入数量" :clearBtn="true" :disabled="false" type="number"/> </div> </lc-cell> <lc-cell :isLink="true" > <div slot="title" class="selected-option"> <lc-textinput v-model="item.price" :hasBorder="false" placeholder="请输入价格" :clearBtn="true" :disabled="false" type="number"/> </div> </lc-cell> <lc-buttongroup shape="circle" style="margin-top:10px;padding:10px 0;"> <lc-button color="#333" style="background:#eee" @click.native="isEditor=false"> 取消 </lc-button> <lc-button style="background:#42b983" @click.native="isEditor=false"> 确定 </lc-button> </lc-buttongroup> </div> </lc-actionsheet> </div> </template>
<script> import LcTitle from '_mods/title.vue'; import Category from '_mods/category.vue'; export default { components: { LcTitle, Category }, data() { return { dialogShow: false, isEditor:false, item:{} }; }, methods: { showDialog1: function() { const options = { title: "确定删除此订单?", content: "删除后将从你的记录里消失,无法找回" };
this.$dialog(options); }, showDialog2: function() { const options = { title: "确定要加入购物车吗?" };
this.$dialog(options); }, showDialog3: function() { const options = { content: "点击返回将中断注册,确定返回?<br>删除后您可以在回收站还原。", noCloseBtn: false, noOkBtn: true, cancelBtnTxt: "我知道了" };
this.$dialog(options); }, showDialog4: function() { const options = { customClass: "my-dialog", title: "注册说明", content: "原账号为您本人所有,建议直接登录或找回密码。原账号内的订单资产可能丢失,可联系京东客服找回。", closeBtn: true, noFooter: true };
this.$dialog(options); }, showDialog5: function() { const options = { okBtnTxt: "好 的", title: "事件", content: "点击按钮触发事件", closeBtn: true, onOkBtn(event) { alert("okBtn"); this.close(); }, onCancelBtn(event) { alert("cancelBtn"); }, onCloseBtn(event) { alert("closeBtn"); }, closeCallback(target) { alert("will close"); } };
this.$dialog(options); }, showDialog6: function() { this.$dialog({ animation: false, title: "注册说明", content: "原账号为您本人所有,建议直接登录或找回密码。原账号内的订单资产可能丢失,可联系京东客服找回。" }); }, showDialog7: function() { this.$dialog({ maskBgStyle: "rgba(0,0,0,0)", title: "注册说明", content: "原账号为您本人所有,建议直接登录或找回密码。原账号内的订单资产可能丢失,可联系京东客服找回。" }); }, showDialog8: function() { this.$dialog({ title: "背景滚动锁定", lockBgScroll: true, content: "弹窗弹出后,页面滚动锁止。在窗体和遮罩层上滑动时,页面不再跟随滚动。", noOkBtn: true, cancelBtnTxt: "我知道了" }); }, showDialog9: function() { this.$dialog({ title: "《桃花行》", lockBgScroll: true, content: "桃花帘外东风软,<br>桃花帘内晨妆懒。<br>帘外桃花帘内人,<br>人与桃花隔不远。<br>东风有意揭帘栊,<br>花欲窥人帘不卷。<br>桃花帘外开仍旧,<br>帘中人比桃花瘦。<br>花解怜人花也愁,<br>隔帘消息风吹透。<br>风透帘栊花满庭,<br>庭前春色倍伤情。<br>闲苔院落帘空卷,<br>斜日栏干人自凭。<br>凭栏人向东风泣,<br>茜裙偷傍桃花立。<br>桃花桃叶乱纷纷,<br>花绽新红叶凝碧。<br>树树烟封一万株,<br>烘照楼台红模糊。<br>天机烧破鸳鸯锦,<br>春色欲酣珊瑚枕。<br>侍女金盆进水来,<br>香泉欲蘸胭脂冷。<br>胭脂鲜艳何相类,<br>花之颜色人之泪。<br>若将人泪比桃花,<br>泪自长流花自媚。<br>泪眼看花泪易乾,<br>泪乾春尽花憔悴。<br>憔悴花枝憔悴人,<br>花飞人倦易黄昏。<br>一声杜宇春归尽,<br>寂寞帘栊空月痕。", noOkBtn: true, cancelBtnTxt: "我知道了" }); }, showImageDialog: function() { this.$dialog({ type: "image", link: "http://m.jd.com", imgSrc: "https://m.360buyimg.com/mobilecms/s750x750_jfs/t1/4875/23/1968/285655/5b9549eeE4997a18c/070eaf5bddf26be8.jpg!q80.dpg", onClickImageLink: function() { console.log(this); return false; } }); } } }; </script> <style lang="less" scoped> p{ line-height: 26px; padding:10px; font-size: 14px;} </style>
|