vue实现一个移动端屏蔽滑动的遮罩层

这个是原文章的地址:点这里

在扯废话浪费大家的时间之前,先上个代码好了,使用vue实现起来很简单……

    <div class="overlayer" @touchmove.prevent >
    </div>

对,就是这么简单,加上@touchmove.prevent就可以屏蔽滑动页面了,然后再和普通的遮罩层一样,加点样式

/*遮罩层*/
.overlayer{
    position:fixed;
    left:0;
    top:0;
    width:100%;
    height:100%;
    z-index:10;
}

如此,便可以了_(:з)∠)_,vue真是好用啊……

以下是废话和原理

开发移动端页面的时候有一个很比较常见的需求,在出现弹窗时,禁止滑动弹窗后面的主体页面;
实际上大部分弹窗插件(或者组件)都带了这样的功能,所以我自己也从来没研究过这个;
这次的项目突然出现了一个需要自己写弹窗的场景……我瞬间就懵逼了QwQ
虽然毫无思路,但是代码还是要写的,效果还是要实现的,问题还是要解决的,而程序员解决问题的第一步,自然就是先去百度一下;
一般来讲吧,普通问题都可以直接百度解决,百度不到的再考虑问人,屏蔽滑动的遮罩层这样常见的需求,自然是有一大堆的解决方案,不过……太多了根本没法选啊(╯‵□′)╯︵┻━┻
随便试了一套方案,未果,遂放弃了继续尝试的打算……还是去翻别人的源码吧。
首先想到了mint ui中的popup组件;
认真阅读了一下,发现这个遮罩层也没做什么事情,就是屏蔽了一下touchmove事件,拿到这个思路再回去自己查了下资料,移动端的屏幕滑动,实际上就是touchmove事件的默认行为,在冒泡过程中任何一层阻止这个默认行为,都可以阻止屏幕滑动,弄懂原理,实现起来就简单了,传统做法是在body上添加一个touchmove事件处理器,在显示遮罩层的时候使用.preventDefault()方法阻止默认行为,而vue就更简单了,把弹窗之类的都写在遮罩层元素内部,然后直接在遮罩层上加上一个取消默认行为的事件处理器,就可以咯~

注意!

如果弹窗不在遮罩层内部,那么冒泡就不会经过遮罩层,也就无法屏蔽滑动了0.0

    <div class="overlayer" @touchmove.prevent >
    </div>
    <div class="popup">
        如果在这个div中滑动,触发的事件是不会经过overlayer的,也就无法屏蔽滑动了
    </div>

如果实在不能把弹窗放到遮罩层内,那么给弹窗加一个单独的 .prevent 修饰符也可以,下面这两种方式都是有效的:

   <!--plan A-->
    <div class="overlayer" @touchmove.prevent >
        <div class="popup">
            如果在这个div中滑动,触发的事件会经过overlayer,可以屏蔽滑动
        </div>
    </div>

   <!--plan B-->
    <div class="overlayer" @touchmove.prevent >
    </div>
    <div class="popup"  @touchmove.prevent>
        如果在这个div中滑动,触发的事件也会被禁用默认行为, 也可以屏蔽滑动
    </div>

PC端方案

这种屏蔽方式只是屏蔽了滑动,对于PC端的鼠标滚轮是无效的,但屏蔽鼠标滚轮也很简单,把 touchmove 事件处理器改成 scroll 事件的处理器就好了~就像这样:

    <div class="overlayer" @scroll.prevent >
    </div>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要了解如何在移动端录音。可以使用HTML5提供的MediaRecorder API来实现。这个API允许我们在浏览器中录制媒体数据,如音频或视频。 以下是一个使用MediaRecorder API录制音频的示例代码: ```javascript // 获取用户麦克风权限 navigator.mediaDevices.getUserMedia({ audio: true }) .then(stream => { // 创建 MediaRecorder 对象 const mediaRecorder = new MediaRecorder(stream); // 录音数据存储数组 const chunks = []; // 开始录音 mediaRecorder.start(); // 监听录音数据 mediaRecorder.addEventListener("dataavailable", event => { chunks.push(event.data); }); // 停止录音 mediaRecorder.addEventListener("stop", () => { // 合并录音数据为 Blob 对象 const blob = new Blob(chunks, { type: "audio/mp3" }); // 播放录音 const audio = new Audio(URL.createObjectURL(blob)); audio.play(); }); // 停止录音 setTimeout(() => { mediaRecorder.stop(); }, 5000); }); ``` 以上代码会在用户授权后开始录制5秒钟的音频,并将其保存为Blob对象。你可以将其发送到服务器进行处理或保存。 接下来,你需要使用Vue.js来构建你的应用程序。你可以使用Vue CLI来创建一个新项目: ``` vue create my-project ``` 一旦你完成了项目的创建,你可以使用Vue Router来实现路由跳转: ```javascript import Vue from "vue"; import Router from "vue-router"; import Record from "@/views/Record.vue"; import Play from "@/views/Play.vue"; Vue.use(Router); export default new Router({ routes: [ { path: "/", name: "record", component: Record }, { path: "/play", name: "play", component: Play } ] }); ``` 在上面的代码中,我们定义了两个路由,一个用于录音,另一个用于播放录音。 接下来,我们可以创建两个视图组件来处理这两个路由: ```vue <template> <div> <button @click="startRecording">Start Recording</button> <button @click="stopRecording">Stop Recording</button> <button @click="uploadRecording">Upload Recording</button> </div> </template> <script> export default { data() { return { mediaRecorder: null, chunks: [], recording: false }; }, methods: { startRecording() { navigator.mediaDevices.getUserMedia({ audio: true }).then(stream => { this.mediaRecorder = new MediaRecorder(stream); this.chunks = []; this.recording = true; this.mediaRecorder.start(); this.mediaRecorder.addEventListener("dataavailable", event => { this.chunks.push(event.data); }); }); }, stopRecording() { if (this.mediaRecorder) { this.mediaRecorder.stop(); this.recording = false; } }, uploadRecording() { if (this.chunks.length > 0) { const blob = new Blob(this.chunks, { type: "audio/mp3" }); const formData = new FormData(); formData.append("file", blob); // 发送录音数据到服务器 } } } }; </script> ``` 以上代码实现了录音功能。当用户点击“Start Recording”按钮时,我们请求麦克风权限并开始录音。我们使用MediaRecorder API监听“dataavailable”事件来获取录音数据。当用户点击“Stop Recording”按钮时,我们停止录音。当用户点击“Upload Recording”按钮时,我们将录音数据发送到服务器。 ```vue <template> <div> <audio ref="audio" controls></audio> </div> </template> <script> export default { mounted() { const audio = this.$refs.audio; const blob = this.$route.query.blob; audio.src = URL.createObjectURL(blob); audio.play(); } }; </script> ``` 以上代码实现了播放录音功能。当用户访问“/play”路由时,我们从URL参数中获取Blob对象并将其设置为音频播放器的源。 最后,我们需要在Vue实例中使用Vue Router和我们创建的路由: ```javascript import Vue from "vue"; import App from "./App.vue"; import router from "./router"; Vue.config.productionTip = false; new Vue({ router, render: h => h(App) }).$mount("#app"); ``` 至此,我们完成了一个使用Vue.js实现移动端录音应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值