广告
返回顶部
首页 > 资讯 > 精选 >使用Html5怎么实现一个微信语音功能
  • 954
分享到

使用Html5怎么实现一个微信语音功能

2023-06-09 12:06:41 954人浏览 八月长安
摘要

使用HTML5怎么实现一个微信语音功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。为什么要学会HTML5 的语音呢?html5 规范推进,手机的更新加速了操作

使用HTML5怎么实现一个微信语音功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

为什么要学会HTML5 的语音呢?

html5 规范推进,手机的更新加速了操作系统更新,语音功能将会变成前端主要的工作之一,就像现在的canvas一样。前端实现语音功能开发速度更快,更节省人力(这意味着给老板省钱,给老板省钱就是在给自己涨工资)

即使是现在本地应用做语音功能,熟悉前端语音交互的各种坑能够让你们的同事关系更和谐,协作更顺畅,而不是互相掐架。

了解新的技术可以预防面试,二来可以预判技术潮流,不至于学了一堆屠龙之技或者墨守成规,更有利于让自己的知识和职业核心竞争力一直处在食物链的顶端。

前端大部分人对语音功能有误解,以为语音功能就是HTML5 audio标签而已,事实上真的不是那么简单的"而已"

不墨迹那么多,咱们直接开发一个小项目啥都明明白儿白儿了,先看效果图

clipboard.png

业务逻辑非常简单,

跟我们微信用法一模一样,手按下去字变成松开结束,同时说话被录下来,松手的时候,变成按下结束,同时发送语音给对方

我们一步一步一步来,首先我们先整一个html页面

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta Http-equiv="X-UA-Compatible" content="ie=edge">    <title>微信语音</title>    <link rel="stylesheet" href="CSS/record.css"></head><body>    <div id="wrap">        <header id="header">            <div id="left">                <i class="material-icons">                    chevron_left                </i>                微信(184)            </div>            <div id="mid">艾达&middot;王</div>            <div id="right">                <i class="material-icons">                    more_horiz                </i>            </div>        </header>        <div id="contentWrap">            <ul id="chatList">                <li class="item_me">                    <div class="chatContent">我是不是你最疼爱的人?                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">奔跑吧,兄弟!(滚犊子)                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">这里我就不多说了,上来就是一梭子代码&hellip;&hellip;                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">大彬哥,你说你咋这么优秀呢?看见你我有一种大海的感觉                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">老妹儿,你是不是喜欢上我了呢&hellip;&hellip;                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">不是,我晕船,看见你想吐&hellip;&hellip;                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>            </ul>        </div>        <footer id="footer">            <div id="keyboard">                <i class="material-icons">                    keyboard                </i>            </div>            <div id="sayBtn">                <span id="sendBtn" class="sendBtn">按下 说话</span>            </div>            <div id="icon"><i class="material-icons">                    sentiment_satisfied                </i></div>            <div id="add"><i class="material-icons">                    add_circle_outline                </i></div>        </footer>    </div></body></html>

css部分,

*{    margin: 0;    padding: 0;}ul li{ list-style: none;}html,body{    height: 100%;    width: 100%;    overflow: hidden;}body{    background: #ebebeb;}@font-face {    font-family: 'Material Icons';    font-style: nORMal;    font-weight: 400;    src: url(../css/iconfont/MaterialIcons-Regular.eot);     src: local('Material Icons'),      local('MaterialIcons-Regular'),      url(../css/iconfont/MaterialIcons-Regular.woff) format('woff2'),      url(../css/iconfont/MaterialIcons-Regular.woff2) format('woff'),      url(../css/iconfont/MaterialIcons-Regular.ttf) format('truetype');  }  .material-icons {    font-family: 'Material Icons';    font-weight: normal;    font-style: normal;    font-size: 32px;      display: inline-block;        text-transform: none;    letter-spacing: normal;    Word-wrap: normal;    white-space: nowrap;    direction: ltr;          -WEBkit-font-smoothing: antialiased;        text-rendering: optimizeLegibility;          -moz-osx-font-smoothing: grayscale;          font-feature-settings: 'liga';  }#wrap{    display: flex;    flex-direction: column;    justify-content: space-between;    height: 100%;}#header{    height: 46px;    line-height: 46px;    background: #363539;    display: flex;    align-items: center;    color: #fff;    justify-content: space-between;}#header #left{    display: flex;    align-items: center;    font-size: 14px;    width: 100px;}#header #right{    display: flex;    align-items: center;    width: 100px;    justify-content: flex-end;}#header #right i{    padding-right: 6px;}#header #mid{    text-align: center;    flex: 1;}#contentWrap{    flex: 1;    overflow-y:auto;}.item_me,.item_audio{    display: flex;    align-items: flex-start;    justify-content:flex-end;    padding: 8px;}.item_you{    display: flex;    align-items: flex-start;    justify-content:flex-start;    padding: 8px;}.avatar{    width: 40px;    height: 40px;}.avatar img{width: 100%;}.item_me .chatContent{    padding: 10px;    background: #a0e75a;    border: 1px solid #6fb44d;    margin-right: 15px;    border-radius: 5px;    position: relative;}.chatContent span{width:0; height:0; font-size:0; overflow:hidden; position:absolute;}.item_me .chatContent span.bot{    border-width:8px;     border-style:solid dashed dashed;     border-color: transparent transparent transparent #6fb44d;     right:-17px;     top:10px;}.item_me .chatContent span.top{    border-width:8px;     border-style:solid dashed dashed;     border-color:transparent transparent transparent #a0e75a ;      right:-15px;     top:10px;} .item_you .chatContent{    padding: 10px;    background: #a0e75a;    border: 1px solid #6fb44d;    margin-left: 15px;    border-radius: 5px;    position: relative;} .item_you .chatContent span.bot{    border-width:8px;     border-style:solid dashed dashed;     border-color: transparent #6fb44d transparent transparent ;     left:-17px;     top:10px;}.item_you .chatContent span.top{    border-width:8px;     border-style:solid dashed dashed;     border-color:transparent #a0e75a transparent transparent  ;      left:-15px;     top:10px;}        #footer{    height: 46px;    padding: 0 4px;    background: #f4f5f6;    border-top: 1px solid #d7d7d8;    display: flex;    align-items: center;    color: #7f8389;    justify-content: space-around;}#sayBtn{    flex: 1;    display: flex;    margin: 0 5px;    color:#565656;    font-weight: bold;}.sendBtn{    display: block;    flex: 1;    padding: 8px;    background: #f4f5f6;    border:1px solid #bec2c1;    border-radius: 5px;    text-align: center;}.activeBtn{    display: block;    flex: 1;    padding: 8px;    background: #c6c7ca;    border:1px solid #bec2c1;    border-radius: 5px;    text-align: center;}.item_audio .chatContent{    padding: 6px;    background: #fff;    border: 1px solid #999;    border-radius: 5px;    margin-right: 15px;    position: relative;    width:120px;    min-height: 20px;}.item_audio .chatContent span.bot{    border-width:8px;     border-style:solid dashed dashed;     border-color: transparent transparent transparent #999;     right:-17px;     top:10px;}.item_audio .chatContent span.top{    border-width:8px;     border-style:solid dashed dashed;     border-color:transparent transparent transparent #fff ;      right:-15px;     top:10px;} .material-icons_wifi{    transform: rotate(90deg);    color: #a5a5a5;    font-size: 22px;}.redDot{    background: #f45454;    border-radius: 50%;    width: 8px;    height: 8px;    margin-right: 10px;}

这里我说两个注意点,

html部分:

图省事我并没有像素级切图,图省事我也直接用了svg图标,具体库我使用的是

https://material.io/tools/icons/?style=outline

css部分:使用flex布局。我只是为了讲解Html5功能,所以flex并没有写兼容性写法,另外App头部部分写法大家注意一下,那里是非常常用的。

下面说重点js部分。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <meta http-equiv="X-UA-Compatible" content="ie=edge">    <title>微信语音</title>    <link rel="stylesheet" href="css/record.css">    <script>        document.addEventListener('DOMContentLoaded', function () {            var oSendBtn = document.getElementById('sendBtn');            var soundClips = document.querySelector('.sound-clips');            var mediaRecorder;            var oChatList = document.getElementById('chatList');            navigator.getUserMedia = (navigator.getUserMedia ||                navigator.webkitGetUserMedia ||                navigator.mozGetUserMedia ||                navigator.msGetUserMedia);            if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {                navigator.mediaDevices.getUserMedia(                    // constraints - only audio needed for this app                    {                        audio: true                    })                    // Success callback                    .then(function (stream) {                        rec(stream);                    })                    // Error callback                    .catch(function (err) {                    }                    );            } else {            }             function rec(stream) {                mediaRecorder = new MediaRecorder(stream);                oSendBtn.addEventListener('touchstart', function (ev) {                    ev.preventDefault();                    this.innerHTML = '松开 结束';                    this.classList.add('activeBtn');                    mediaRecorder.start();                }, false);                oSendBtn.addEventListener('touchend', function (ev) {                    ev.preventDefault();                    this.innerHTML = '按下 说话';                    this.classList.remove('activeBtn');                    mediaRecorder.stop();                }, false);                mediaRecorder.ondataavailable = function (e) {                    var clipContainer = document.createElement('li');                    var audio = document.createElement('audio');                    clipContainer.classList.add('item_audio');                    clipContainer.innerHTML = `                    <div class = "redDot"></div>                    <div class="chatContent">                        <i class="material-icons material-icons_wifi">wifi</i>                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>`;                    audio.setAttribute('controls', '');                    oChatList.appendChild(clipContainer);                    var audioURL = window.URL.createObjectURL(e.data);                    audio.src = audioURL;                    oChatList.addEventListener('touchstart', function (ev) {                        if (ev.srcElement.parentnode.className!== 'item_audio') return;                        audio.play();                        ev.srcElement.parentNode.removeChild(ev.srcElement.parentNode.children[0])                    }, false);                };            }        }, false);    </script></head><body>    <div id="wrap">        <header id="header">            <div id="left">                <i class="material-icons">                    chevron_left                </i>                微信(184)            </div>            <div id="mid">艾达&middot;王</div>            <div id="right">                <i class="material-icons">                    more_horiz                </i>            </div>        </header>        <div id="contentWrap">            <ul id="chatList">                <li class="item_me">                    <div class="chatContent">我是不是你最疼爱的人?                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">奔跑吧,兄弟!(滚犊子)                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">这里我就不多说了,上来就是一梭子代码&hellip;&hellip;                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">大彬哥,你说你咋这么优秀呢?看见你我有一种大海的感觉                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>                <li class="item_me">                    <div class="chatContent">老妹儿,你是不是喜欢上我了呢&hellip;&hellip;                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>                </li>                <li class="item_you">                    <div class="avatar">                        <img src="images/ava2.jpg" alt="">                    </div>                    <div class="chatContent">不是,我晕船,看见你想吐&hellip;&hellip;                        <span class="bot"></span>                        <span class="top"></span>                    </div>                </li>            </ul>        </div>        <footer id="footer">            <div id="keyboard">                <i class="material-icons">                    keyboard                </i>            </div>            <div id="sayBtn">                <span id="sendBtn" class="sendBtn">按下 说话</span>            </div>            <div id="icon"><i class="material-icons">                    sentiment_satisfied                </i></div>            <div id="add"><i class="material-icons">                    add_circle_outline                </i></div>        </footer>    </div></body></html>

这里实现的录影功能要注意的点很多,我们一个个说,

第一个东西,

navigator.getUserMedia = (navigator.getUserMedia ||                navigator.webkitGetUserMedia ||                navigator.mozGetUserMedia ||                navigator.msGetUserMedia);            if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {                navigator.mediaDevices.getUserMedia(                    {                        audio: true                    })                    // Success callback                    .then(function (stream) {                        rec(stream);                    })                    // Error callback                    .catch(function (err) {                    }                    );            } else {            }

当大家看一些html5关于录音的接口的时候,你看到这个

Navigator.getUserMedia()

就要小心了,这个是老规范的东西了,被废了,新的是

navigator.mediaDevices.getUserMedia

html5 多媒体里面的语音这块换了好几茬规范,很乱,有些标签甚至一个浏览器都没实现过,未曾绽放就枯萎了,你也不用关心也没必要浪费那个时间知道,你只要知道我说这些就够了,因为你知道那些被废掉的过往没啥用,有那个时间还不如来一局LOL或者王者荣耀(虽然我并不懂二者的区别,不过这两个游戏应该都挺好玩吧,没玩过不懂)。

里面的东西大家也不需要看懂,什么promise了,什么媒体流了,你不用知道,你就知道这样一件事就行了,

上面的代码就相当于打开了水龙头(或者说按下的录音机的录音键),那么我们得有东西接着水啊,我们可以用电饭锅(录音机的话就是磁带)放水龙头下面看着它往里面ci(我们老家话,射的意思),如下代码

mediaRecorder = new MediaRecorder(stream);

接下来就是,一按按钮就生米煮成熟饭了,对应录音机就是录完了按按钮就播放了,但是在我们程序里面要想播放你不仅要有磁带,还得有录音机,录音机就是audio标签,没有好办,我们new一个。这个世界上没有什么对象是程序员不敢new的,new一个不行,就new两个。剩下的代码除了吓人之外,没啥缺点,简单的令人发指。

mediaRecorder.ondataavailable = function (e) {                    var clipContainer = document.createElement('li');                    var audio = document.createElement('audio');                    clipContainer.classList.add('item_audio');                    clipContainer.innerHTML = `                    <div class = "redDot"></div>                    <div class="chatContent">                        <i class="material-icons material-icons_wifi">wifi</i>                        <span class="bot"></span>                        <span class="top"></span>                    </div>                    <div class="avatar">                        <img src="images/ava1.png" alt="">                    </div>`;                    audio.setAttribute('controls', '');                    oChatList.appendChild(clipContainer);                    var audioURL = window.URL.createObjectURL(e.data);                    audio.src = audioURL;                    oChatList.addEventListener('touchstart', function (ev) {                        if (ev.srcElement.parentNode.className!== 'item_audio') return;                        audio.play();                        ev.srcElement.parentNode.removeChild(ev.srcElement.parentNode.children[0])                    }, false);                };

其实就是录好了就播。

OK,是不是很简单 ,整个项目我说几个点吧:

切图结构合理是你后面做功能的前提,结构做的好,后面就省事,想想诸葛不亮吧,未出茅庐人家就把html5结构搭好了,有三个section.

原生js和es6的基础打牢可以为你提供不同的思路,比如我这里就使用了事件委托,还有ES6模板引擎。尤其是事件委托,不用的话查找节点很麻烦,另外代码套来套去也容易乱。

新的 知识和技术其实并不复杂,其实很简单,你想如果新技术不是为了让功能更好实现,更能解决我们的问题,那开发新技术干嘛?因为那帮大胡子的大牛们没事干怕被领导说工作量不饱和?技术是为了解决问题和让我们生活更美好服务的。

这个项目iOS 11以下跑不通,因为IOS 11.2之前不支持这个方法,需要IOS本地应用开发人员给你提供支援,但是在Android下面是很OK的。而且可以预见,再过几年IOS 原生也不用给你支援都支持了,那你开发效率得多高。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网精选频道,感谢您对编程网的支持。

--结束END--

本文标题: 使用Html5怎么实现一个微信语音功能

本文链接: https://www.lsjlt.com/news/256003.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 使用Html5怎么实现一个微信语音功能
    使用Html5怎么实现一个微信语音功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。为什么要学会HTML5 的语音呢?Html5 规范推进,手机的更新加速了操作...
    99+
    2023-06-09
  • 使用Html5怎么实现一个语音搜索功能
    这篇文章给大家介绍使用Html5怎么实现一个语音搜索功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。html是什么html的全称为超文本标记语言,它是一种标记语言,包含了一系列标签.通过这些标签可以将网络上的文档格式...
    99+
    2023-06-09
  • JS怎么实现一个微信录音功能
    今天小编给大家分享一下JS怎么实现一个微信录音功能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。拆解需求根据原型图可以很容易...
    99+
    2023-07-05
  • 怎么 在HTML5中实现一个语音合成功能
    怎么 在HTML5中实现一个语音合成功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 Speech Synthesis API通过上面的例子我们可以猜测到上面调用的...
    99+
    2023-06-09
  • 怎么用html5的DeviceOrientation实现微信摇一摇功能
    这篇“怎么用html5的DeviceOrientation实现微信摇一摇功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有...
    99+
    2022-10-19
  • 利用golang怎么实现一个微信支付功能
    本文章向大家介绍利用golang怎么实现一个微信支付功能的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。golang的优点有哪些golang是一种编译语言,可以将代码编译为机器代码,编译后的二进制文件可以直接部署...
    99+
    2023-06-06
  • 怎么在html5项目中实现一个录音功能
    这篇文章给大家介绍怎么在html5项目中实现一个录音功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。步骤1由于新的api是通过navigator.mediaDevices.getUserMedia,且返回一个prom...
    99+
    2023-06-09
  • JS实现一个微信录音功能过程示例详解
    目录功能原型图拆解需求评估时间代码实现功能原型图 其实就是微信发送语音的功能。没有转文字的功能。 拆解需求 根据原型图可以很容易的得出我们需要做的内容包括下面三个部分: 接入微信...
    99+
    2023-02-21
    JS微信录音功能 JS 微信录音
  • 使用Swift怎么实现一个最小化语音通话功能
    本篇文章为大家展示了使用Swift怎么实现一个最小化语音通话功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。SuspendToolimport Foundationimport ...
    99+
    2023-06-06
  • Flutter中怎么实现一个微信朋友圈功能
    这篇文章给大家介绍Flutter中怎么实现一个微信朋友圈功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。import 'package:dio/dio.dart';import &...
    99+
    2023-06-20
  • 使用java如何实现一个微信H5支付功能
    这篇文章将为大家详细讲解有关使用java如何实现一个微信H5支付功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前面做了app微信支付的回调处理,现在需要做微信公众号的支付,花了一天多时间...
    99+
    2023-05-31
    h5支付 java
  • 怎么在Html5中实现微信分享功能
    这期内容当中小编将会给大家带来有关怎么在Html5中实现微信分享功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、安装 weixin-js-sdknpm install weixin-js-...
    99+
    2023-06-09
  • 使用fabric.js怎么实现一个明信片功能
    使用fabric.js怎么实现一个明信片功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、fabric.js是一个很好用的 canvas 操作插件示例:pandas 是...
    99+
    2023-06-14
  • 微信小程序使用同声传译实现语音识别功能
      我使用同声传译语音识别功能是为了实现微信小程序首页的语音搜索功能,如果你也是那么恭喜你,你可以ctrl+c、ctrl+v再改一改,如果你不是那么你也不要着急的走可以看完我的文章会...
    99+
    2022-11-12
  • 怎么在微信小程序中实现一个导航功能
    本篇文章给大家分享的是有关怎么在微信小程序中实现一个导航功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。操作步骤申请腾讯地图key——地址小程序后台添加腾讯插件——开发文档小...
    99+
    2023-06-08
  • 微信小程序中怎么实现一个计算器功能
    微信小程序中怎么实现一个计算器功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。目录结构第一次进到页面它的目录结构如下:需要注意的问题(1)添加的新页面文件,都...
    99+
    2023-06-20
  • 怎么在android中实现一个微信联合登录功能
    怎么在android中实现一个微信联合登录功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1):登录微信开放平台,完成账号申请:https://open.weixin.qq....
    99+
    2023-05-30
    android
  • 怎么在Android应用中实现一个语音消息发送功能
    本篇文章为大家展示了怎么在Android应用中实现一个语音消息发送功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。直接上代码://语音操作对象private MediaPlayer&nb...
    99+
    2023-05-30
    android roi
  • 怎么在html5中使用Geolocation实现一个定位功能
    今天就跟大家聊聊有关怎么在html5中使用Geolocation实现一个定位功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.获取当前位置 我们将使用getCurrentPosi...
    99+
    2023-06-09
  • 怎么使用PHP实现一个短信验证码功能
    本篇内容介绍了“怎么使用PHP实现一个短信验证码功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!第一步:生成短信验证码要生成短信验证码,我...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作