vue實現(xiàn)內(nèi)容可滾動的彈窗效果
本文實例為大家分享了vue實現(xiàn)內(nèi)容可滾動的彈窗效果具體代碼,供大家參考,具體內(nèi)容如下
這是第一種實現(xiàn)方式
效果圖:

彈窗代碼:
Popup.vue
<template lang="html">
<div v-if="show" class="modal-bg" @click="closeModal">
<div class="modal_con">
<div class="modal_content">
<div class="modal-container">
<div class="modal_main">
<p class="modal-header">{{dataList.title}}</p>
<div class="rules_text">
<p
v-for="(item, index) in dataList.rules"
class="rules_txt"
:key="index"
>
{{ item }}
</p>
</div>
</div>
</div>
<div class="footer_rules">
<div class="tips"></div>
<div class="rules_button">
<div class="button" @click="closeModal">
<p class="button_text">我知道了</p>
</div>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
export default {
name: 'Popup',
props: {
show: {
type: Boolean,
default: false
},
},
data () {
return {
dataList: {
rules: [
'1.這是第一條數(shù)據(jù)啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊',
'2.這是第二條數(shù)據(jù)啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊',
'3.這是第三條數(shù)據(jù)啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊',
'4.這是第四條數(shù)據(jù)啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊'
],
reward: [
'1.活動規(guī)則第一條數(shù)據(jù)數(shù)據(jù)數(shù)據(jù)數(shù)據(jù)',
'2.活動規(guī)則第二條數(shù)據(jù)數(shù)據(jù)數(shù)據(jù)',
'2.活動規(guī)則第三條數(shù)據(jù)數(shù)據(jù)數(shù)據(jù)'
]
}
}
},
methods: {
closeModal () {
this.$emit('closeModal')
},
}
}
</script>
<style lang="css" scoped>
.modal_con {
width: 80%;
height: 287px;
background: #ffffff;
overflow: hidden;
margin: 0 auto;
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
border-radius: 8px;
}
.modal_content {
height: 100%;
background-color: #fff;
}
.modal-bg {
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.6);
position: fixed;
top: 0;
left: 0;
z-index: 999;
}
.modal-container {
height: 78%;
text-align: center;
display: flex;
flex-direction: column;
overflow-y: scroll;
/* ios需要下面這個屬性 */
-webkit-overflow-scrolling: touch;
}
.rules_txt {
font-size: 15px;
font-family: PingFangSC, PingFangSC-Regular;
font-weight: 400;
text-align: justify;
color: #666666;
padding: 0 20px;
margin-top: 8px;
margin-bottom: 0;
}
.rules_txt:last-child {
padding-bottom: 40px;
}
.modal-header {
font-size: 17px;
font-family: PingFang, PingFang-SC;
font-weight: bold;
text-align: center;
color: #333333;
margin: 0;
padding-top: 20px;
}
.reward_title {
font-size: 17px;
font-family: PingFang, PingFang-SC;
font-weight: bold;
text-align: center;
color: #333333;
padding: 0;
margin-top: 14px;
margin-bottom: 6px;
}
.footer_rules {
width: 100%;
height: 22%;
position: absolute;
bottom: 0;
}
.tips {
/* width: 100%;
opacity: 0.6;
height: 49px;
background: linear-gradient(180deg, rgba(255, 255, 255, 0.5), #ffffff);
text-align: center;
line-height: 49px;
font-size: 18px; */
}
.rules_button {
width: 100%;
background: #ffffff;
padding-bottom: 20px;
border-bottom-right-radius: 8px;
border-bottom-left-radius: 8px;
}
.button {
width: 90%;
display: flex;
justify-content: center;
align-content: center;
background: linear-gradient(270deg, #1283ff, #50a3ff);
border-radius: 4px;
text-align: center;
margin: 0 auto;
}
.button_text {
font-size: 15px;
font-family: PingFang, PingFang-SC;
font-weight: SC;
color: #ffffff;
display: flex;
justify-content: center;
align-content: center;
margin: 0;
padding: 12px 0;
}
.rules_con {
padding-bottom: 80px;
}
</style>
在Home.vue頁面使用彈窗:
<!-- 活動規(guī)則彈窗 -->
<template>
<div>
<div @click="clickPopup">
<span>點擊彈出彈窗</span>
</div>
<Popup
v-show="isRulesShow"
@closeModal="isRulesShow = false"
:show="isRulesShow"
>
</Popup>
</div>
</template>
<script>
import Popup from './Popup'
export default {
name:"Home",
components: {
Popup
},
data () {
return {
isRulesShow:flase
}
},
watch: {
isRulesShow (v) {
if (v) {
//禁止主頁面滑動方法在main.js
this.noScroll()
} else {
//主頁面可滑動
this.canScroll()
}
},
},
methods:{
//活動規(guī)則彈窗
clickPopup () {
this.isRulesShow = true
},
}
}
</script>
<style lang="scss" scoped>
* {
touch-action: pan-y;
}
</style>
解決彈窗滾動,里面的body也跟著滾動問題
在main.js中
//彈出框禁止滑動
Vue.prototype.noScroll = function () {
var mo = function (e) { e.preventDefault() }
document.body.style.overflow = 'hidden'
document.addEventListener('touchmove', mo, false,{ passive: false })// 禁止頁面滑動
}
//彈出框可以滑動
Vue.prototype.canScroll = function () {
var mo = function (e) {
e.preventDefault()
}
document.body.style.overflow = ''// 出現(xiàn)滾動條
document.removeEventListener('touchmove', mo, false,{ passive: false })
}
在頁面使用時:
//禁止主頁面滑動
this.noScroll()
//主頁面可滑動
this.canScroll()
//還要加上樣式:
* {
touch-action: pan-y;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue實例成員?插值表達(dá)式?過濾器基礎(chǔ)教程示例詳解
這篇文章主要為大家介紹了vue實例成員?插值表達(dá)式?過濾器基礎(chǔ)教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04
vue學(xué)習(xí)筆記之過濾器的基本使用方法實例分析
這篇文章主要介紹了vue學(xué)習(xí)筆記之過濾器的基本使用方法,結(jié)合實例形式分析了vue.js過濾器的基本功能、用法與操作注意事項,需要的朋友可以參考下2020-02-02
vue項目啟動出現(xiàn)cannot GET /服務(wù)錯誤的解決方法
這篇文章主要介紹了vue項目啟動出現(xiàn)cannot GET /服務(wù)錯誤的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
解決vue項目Error:Cannot find module‘xxx’類報錯問題
當(dāng)npm運(yùn)行報錯Error:Cannot find module 'xxx'時,通常是因為node_modules文件或依賴未正確安裝,解決步驟包括刪除node_modules和package-lock.json文件,重新運(yùn)行npm install,并根據(jù)需要安裝額外插件,若網(wǎng)絡(luò)問題導(dǎo)致安裝失敗2024-10-10
vue結(jié)合vant實現(xiàn)聯(lián)動效果
這篇文章主要為大家詳細(xì)介紹了vue結(jié)合vant實現(xiàn)聯(lián)動效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01

