位置: IT常识 - 正文

微信小程序实训|基于云数据库的语文听写工具(微信小程序实训内容)

编辑:rootadmin
微信小程序实训|基于云数据库的语文听写工具

推荐整理分享微信小程序实训|基于云数据库的语文听写工具(微信小程序实训内容),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:微信小程序实训日志,微信小程序实训心得,微信小程序实训心得,微信小程序实训报告万能模板,微信小程序实训感悟,微信小程序实训报告万能模板,微信小程序实训报告心得体会,微信小程序实训总结500字,内容如对您有帮助,希望把文章链接给更多的朋友!

 本实训项目结合云开发的云数据库和 “微信同声传译”插件,制作一个可真实运营的小学生语文听写工具,页面效果如图1所示。

 ▍图1 “听写小助手”页面

基于云开发的微信小程序具有众多优势,云开发模式真正解放了开发者,使得开发效率大大提升,其模式下的小程序开发和交付流程也更加便捷;云开发建立了小程序端通向腾讯云和小程序端通向微信的捷径,也为连接其他更多的腾讯云资源提供了捷径,还可以打通云到云、端到端的界限,其计算资源计费更合理,成本也更低。

在小程序互联网飞速发展的时代,教育场景被重塑,教育类小程序迎来猛增。2020年的新冠疫情为在线教育带来了新活力,推动了用户对在线教育的需求。因此,本团队基于在线教育需求研发了“听写好助手”这款小程序。

“听写好助手”是一个以语文为核心,以微信小程序为窗口,以学生及其家长为服务对象的全语音化教学平台。“听写好助手”集语音听写、错题分析、每日十词、复习提醒、个性定制、阶段复习六项功能于一身,采用语音播报模式,减少学生用眼,大大提高了学生的学习效率,同时也减轻了家长在为孩子辅导听写作业上的压力。

本案例以云开发的云数据库为基础,制作一个面向小学语文听写的微信小程序。

01、开发内容

为了实现“听写小助手”的语音播放功能,需要添加插件“微信同声传译”,具体步骤为:登录微信平台,选择“设置”→“第三方设置”→“插件管理”→“搜索插件”并完成添加。添加插件后打开“控制台”→“数据库”,将数据库文件导入数据库,从而完成了小学六年课后的所有单词的储存。最后为了前后端的用户互动需要用云函数来进行操作,为此要完成同步云函数列表以及上传并部署getContent和getUserCollectList云函数操作,重新编译后选择一年级上册的书,即可实现听写功能。同样的导入剩余的数据库集合即可实现所有书册的听写功能。

听写数据单个集合每条记录包含的字段,如图2所示。

▍图2 rn_11集合导入完成

本案例开发主要包括添加插件、数据库页面、云函数上传部署三个步骤。

1、添加插件

听写好助手的代码中使用了微信同声传译的插件,这是由于听写好助手需要将存在数据库中的文字转换成语音,要让代码正常跑起来,需要登录微信公众平台,在“设置”→“第三方设置”→“插件管理”中,添加插件“微信同声传译”,添加插件后,如图3所示。

▍图3添加插件“微信同声传译”

2、页面数据库

添加完插件后再进行重新编译,会发现还有报错,原因是云开发数据库里没有需要的课本对应的数据记录,因此需要进行数据库的导入。数据库文件具体如图四所示。其中,rn_11对应的是一年级上册的听写数据,rn_12对应的是一年级下册的听写数据,以此类推。

微信小程序实训|基于云数据库的语文听写工具(微信小程序实训内容)

▍图4 数据库文件

3、云函数的上传部署

右击cloudfunctions,选择“同步云函数列表”,完成同步云函数列表以及上传并部署getContent和getUserCollectList云函数操作,重新编译后选择一年级上册的书,即可实现听写功能。同样的导入剩余的数据库集合即可实现所有书册的听写功能,如图5所示。

▍图5 同步云函数列表

02、项目代码

pages/chooseBook/chooseBook.wxml的代码如下:

<view id="chooseBook"> <button class='toCollect' bindtap='toCollect' >错题</button> <button class='button' open-type="feedback"> <icon type="info_circle" color='rgba(255, 0, 0, 0.6)' size="16" style='margin-right:2px;'></icon> <text class='button_title'>反馈建议</text> </button> <view class='tab'> <scroll-view scroll-x="true" class='tab-nav' scroll-left='{{scrollLeft}}' scroll-with-animation="true"> <view wx:for="{{navlist}}" wx:key="unique" class='{{current==index?"on":""}}' data-current="{{index}}" bindtap='tab'>{{item}}</view> </scroll-view> <swiper class='tab-box'zz current="{{current}}" bindchange="eventchange"> <swiper-item wx:for="{{conlist}}" wx:key="unique"> <view class='tip'>左右滑动切换哦</view> <view class="module-container"> <view class="box-wrapper" wx:for="{{item.moudles}}" wx:key="index"> <navigator url="{{item.url}}" hover-class="none"> <view class="servicebox"> <image src="{{item.src}}" class="box-img"/> <text style='font-size: 35rpx;'>{{item.text}}</text> </view> </navigator> </view> </view> </swiper-item> </swiper> </view></view>

 pages/chooseBook/chooseBook.js的代码如下:

const app = getApp()Page({ data: { current: 0,//当前所在滑块的 index navlist: ["一二年级", "三四年级", "五六年级"], //课本列表 conlist: [] }, //tab切换 tab: function (event) { this.setData({ current: event.target.dataset.current }) //锚点处理 }, //滑动事件 eventchange: function (event) { this.setData({ current: event.detail.current }) //锚点处理 }, //生命周期函数--监听页面加载 onLoad: function (options) { this.setData({ conlist: [ { moudles: [ { url: './chooseLesson/chooseLesson?book=rn_11', src: '/img/book/ch_rn_11.jpg', text: '部编版一年级上册' }, { url: './chooseLesson/chooseLesson?book=rn_12', src: '/img/book/ch_rn_12.jpg', text: '部编版一年级下册' }, { url: './chooseLesson/chooseLesson?book=rn_21', src: '/img/book/ch_rn_21.jpg', text: '部编版二年级上册' }, { url: './chooseLesson/chooseLesson?book=rn_22', src: '/img/book/ch_rn_22.jpg', text: '部编版二年级下册' } ] }, { moudles: [ { url: './chooseLesson/chooseLesson?book=rn_31', src: '/img/book/ch_rn_31.jpg', text: '部编版三年级上册' }, { url: './chooseLesson/chooseLesson?book=rn_32', src: '/img/book/ch_rn_32.jpg', text: '部编版三年级下册' }, { url: './chooseLesson/chooseLesson?book=rn_41', src: '/img/book/ch_rn_41.jpg', text: '人教版四年级上册' }, { url: './chooseLesson/chooseLesson?book=rn_42', src: '/img/book/ch_rn_42.jpg', text: '人教版四年级下册' } ] }, { moudles: [ { url: './chooseLesson/chooseLesson?book=rn_51', src: '/img/book/ch_rn_51.jpg', text: '人教版五年级上册' }, { url: './chooseLesson/chooseLesson?book=rn_52', src: '/img/book/ch_rn_52.jpg', text: '人教版五年级下册' }, { url: './chooseLesson/chooseLesson?book=rn_61', src: '/img/book/ch_rn_61.jpg', text: '人教版六年级上册' }, { url: './chooseLesson/chooseLesson?book=rn_62', src: '/img/book/ch_rn_62.jpg', text: '人教版六年级下册' } ] }, ], }) }, toCollect: function () { wx.navigateTo({ url: "../user/collectList/collectList", }) }, onReady: function () {}, onShow: function () {}, onHide: function () {}, onUnload: function () {}, onPullDownRefresh: function () {}, onReachBottom: function () {}, onShareAppMessage: function () {}})

 pages/chooseBook/chooseBook.wxss的代码如下:

.button { position: fixed; left: 20rpx; bottom: 30rpx; background: #FAF0E6; border: none; text-align: left; margin: 0px; line-height: 1.6; border-radius: 0;}.button::after { border: none; border-radius: 0;}.button_title { font-size: 12px; color: rgb(114, 112, 112);}.toCollect { position: fixed; bottom: 100rpx; right: 40rpx; font-size: 40rpx; height: 70rpx; line-height: 70rpx; background-color: rgba(255, 213, 124, 0.925); z-index: 999; box-shadow: 2px 2px 2px #bbb;}/* tab切换效果 */swiper { height: 1000rpx;}.tab{ padding: 20rpx 0;}.tab-nav{ height: 80rpx; line-height: 80rpx;}.tab-nav view{ float: left; height: 80rpx; line-height: 80rpx; background: #FAF0E6; width: 33.33%; font-size: 30rpx; text-align: center; color: #000;}.tab-nav view.on{ background: #FAF0E6; color: rgb(255, 201, 18); position: relative;}.tab-nav view.on:after{ content: ""; display: block; height: 6rpx; width: 26px; background: rgb(243, 189, 10); position: absolute; bottom: 2px; left: calc(50% - 12px); border-radius: 16rpx;}.tip { color: #aaa; text-align: center; font-size: 35rpx; margin-top: 20rpx;}/* 书本选项 */#chooseBook .module-container { width: 100%; display: flex; flex-wrap:wrap; box-sizing: border-box; flex-direction:row; justify-content: center; margin-top: 55rpx;}#chooseBook .module-container .box-wrapper{ height: 300rpx; width: 200rpx; margin: 0 70rpx; margin-bottom: 95rpx;}/* 服务选项 */#chooseBook .module-container .box-wrapper .servicebox{ display:flex; flex-direction:column; justify-content:center; align-items:center; text-align: center;}#chooseBook .module-container .box-wrapper .servicebox .box-img{ height:250rpx; width: 100%; margin-bottom: 10rpx; box-shadow: 2px 2px 3px #aaa;}

 代码讲解

chooseBook.js的onLoad()函数为conlist列表中每个元素设置对应的url、src和text内容,以此将这些数据绑定在chooseBook.wxml中,运行程序便可渲染显示出来。

pages/chooseBook/chooseLesson/chooseLesson.wxml的代码如下:

<view id="listen"> <view class='tab'> <scroll-view scroll-x="true" class='tab-nav' scroll-left='{{scrollLeft}}' scroll-with-animation="true"> <view class='tab-nav-c' style='width:{{conlist.length*90}}px'> <view wx:for="{{conlist}}" wx:key="unit" class='{{current==index?"on":""}}' data-current="{{index}}" bindtap='tab'>第{{index==0?'一':index==1?'二':index==2?'三':index==3?'四':index==4?'五':index==5?'六':index==6?'七':index==7?'八':index==8?'九':index==9?'十':''}}单元</view> </view> </scroll-view> </view> <view class='swiper-box'> <swiper class='swiper' style='height:{{conlist[current].length*150+135}}rpx;' current="{{current}}" bindchange="eventchange"> <swiper-item wx:for="{{conlist}}" wx:key="unit"> <view class='tip'>左右滑动切换哦</view> <view class="module-container"> <view class="box-wrapper" wx:for="{{item}}" wx:key="index"> <view class="text-box"> <text>{{item.title}}</text> </view> <view class="img-box" data-content='{{item}}' bindtap='toDetail'> <image src='/img/listen2.png' mode="widthFix"></image> </view> </view> </view> </swiper-item> </swiper> </view></view>

 pages/chooseBook/chooseLesson/chooseLesson.js的代码如下:

const db = wx.cloud.database();const _ = db.command;let plugin = requirePlugin("WechatSI");let manager = plugin.getRecordRecognitionManager();const innerAudioContext = wx.createInnerAudioContext();let that;let book;Page({ data: { current: 0,//当前所在滑块的 index scrollLeft: -90,//滚动条的位置,一个选项卡宽度是90(自定义来自css),按比例90*n设置位置 conlist: [], }, //tab切换 tab: function (event) { // console.log(event.target.dataset.current); this.setData({ current: event.target.dataset.current }) //锚点处理 this.setData({ scrollLeft: event.target.dataset.current * 90 - 90, }) }, //滑动事件 eventchange: function (event) { console.log(event.detail.current) this.setData({ current: event.detail.current }) //锚点处理 this.setData({ scrollLeft: event.detail.current * 90 - 90, }) }, toDetail: function (e) { let content = ''; let speak = ''; for (let word of e.currentTarget.dataset.content.content) { content = content + word + '/'; } if (e.currentTarget.dataset.content.speak) { for (let word of e.currentTarget.dataset.content.speak) { speak = speak + word + '/'; } } wx.navigateTo({ url: './detail/detail?content=' + content + '&speak=' + speak + '&book=' + book, }) }, onLoad: function (options) { wx.showLoading({ title: '加载中', }); book = options.book; that = this; // setNavigationBarTitle let bookName = '语文'; let bookLevel = { "11": "一年级上册", "12": "一年级下册", "21": "二年级上册", "22": "二年级下册", "31": "三年级上册", "32": "三年级下册", "41": "四年级上册", "42": "四年级下册", "51": "五年级上册", "52": "五年级下册", "61": "六年级上册", "62": "六年级下册", } if (book.search("su") != -1) { bookName += '苏教版' } else if (book.search("zh") != -1) { bookName += '浙教版' } else if (book.search("rn") != -1 && (book.search("4") != -1 || book.search("5") != -1 || book.search("6") != -1)) { bookName += '人教版' } else { bookName += '部编版' } for (let key in bookLevel) { if (book.search(key) != -1) { bookName += bookLevel[key] } } wx.setNavigationBarTitle({ title: bookName }) let dbBook = book; let conlist = []; // 使用云函数,能读100条 wx.cloud.callFunction({ name: 'getContent', data: { dbBook: dbBook } }).then(res => { that.setData({ conlist: res.result }); wx.hideLoading(); }) }, onReady: function () { }, onShow: function () { }, onHide: function () { }, onUnload: function () { innerAudioContext.offPlay(); }, onPullDownRefresh: function () { }, onReachBottom: function () {}, onShareAppMessage: function () { }})

 pages/chooseBook/chooseLesson/chooseLesson.wxss的代码如下:

page {  background-color: #fff;}/* tab切换效果 */.swiper-box {  /* overflow-y: scroll; */  height: 90%;  position: absolute;  width: 100%;}.swiper {  min-height: 100%;  width: 100%;  height: 100%;}.tip {  color: #888;  /* border-bottom: 1px solid #f2f2f2; */  text-align: center;  font-size: 35rpx;  line-height: 35rpx;  padding: 30rpx;}scroll-view{  width: 100%;  height: 100%;/*动态高度*/  overflow-y: scroll;}/* 顶部tab */.tab{  height: 80rpx;  box-shadow: 0px 2px 3px #888888;}.tab-nav{  height: 80rpx;  line-height: 80rpx;  width: 100%;  background-color: #FAF0E6;}.tab-nav .tab-nav-c view{  height: 80rpx;  line-height: 80rpx;  float: left;  width: 90px;  font-size: 30rpx;  text-align: center;  color: #000;}.tab-nav view.on{  background: #FAF0E6;  color: rgb(255, 201, 18);  position: relative;}.tab-nav view.on:after{   content: "";   display: block;   height: 6rpx;   width: 26px;   background: rgb(243, 189, 10);   position: absolute;   bottom: 2px;   left: 32px;   border-radius: 16rpx;}/* 词语 */#listen .module-container {  width: 100%;  display: flex;  flex-wrap:nowrap;  flex-direction:column;  justify-content: center;  align-items: center;}#listen .module-container .box-wrapper{  background-color: #f2f2f2;  border-bottom: 1px solid #c2c2c2;  display: flex;  flex-direction: row;  align-items: center;  flex-wrap:nowrap;  width: 100%;  height: 150rpx;  justify-content: center;}#listen .module-container .box-wrapper .text-box{  display: flex;  width: 70%;  flex-direction: row;  flex-wrap: wrap;  justify-content: center;}#listen .module-container .box-wrapper .text-box text{  font-size: 40rpx;  text-align: center;  line-height: 60rpx;}#listen .module-container .box-wrapper .img-box {  width: 20%;}#listen .module-container .box-wrapper .img-box image {  width: 100%;}/* 服务选项 */#listen .module-container .box-wrapper .servicebox{  display:flex;  flex-direction:column;  justify-content:center;  align-items:center;  text-align: center;}#listen .module-container .box-wrapper .servicebox .box-img{  height:250rpx;  width: 100%;  margin-bottom: 5rpx;}

 代码讲解

chooseLesson .js的onLoad()函数自动执行对云数据库的查询操作,获取到云数据库中课本的数据,并赋值给“book”,然后通过数据绑定的方式在chooseLesson.wxml中进行渲染显示。

pages/chooseBook/chooseLesson/detail/detail.wxml的代码如下:

<view id='detail'> <van-transition name="fade" duration='1000' show="{{show}}" style="{{i==sum?'display:none':''}}"> <view style="width:80%;margin:0 auto;position:relitive;top:-80rpx;"> <van-steps steps="{{ steps }}" active="{{ active }}" /> </view> <view class="page__bd"> <view class="icon-box" bindtap='preWord'> <image class='icon' style=' width: 150rpx;height: 150rpx;' src="/img/pre.png" >上一个</image> <view class="icon-box__ctn"> <view class="icon-box__title">上一个</view> </view> </view> <view class="icon-box" bindtap='nextWord'> <image class='icon' src="/img/{{(i==-1?'start':i==sum-1?'end':'next')}}.png" >下一个</image> <view class="icon-box__ctn"> <view class="icon-box__title">下一个</view> </view> </view> <view class="icon-box" style='margin-bottom: 0;' bindtap='again'> <image class='icon' style=' width: 150rpx;height: 150rpx;' src="/img/again.png" >再读一遍</image> <view class="icon-box__ctn"> <view class="icon-box__title">再读一遍</view> </view> </view> </view> </van-transition> <view style="{{i<sum?'display:none':''}}"> <view class="weui-cells__title" style="font-size:16px;color:#000;margin-bottom:40rpx;">请校对:</view> <view class="weui-cells weui-cells_after-title"> <checkbox-group bindchange="checkboxChange"> <label class="weui-cell weui-check__label" wx:for="{{content}}" wx:key="index"> <checkbox class="weui-check" value="{{item.value}}" checked="{{item.checked}}"/> <view class="weui-cell__hd weui-check__hd_in-checkbox"> <icon class="weui-icon-checkbox_circle" type="circle" size="23" wx:if="{{!item.checked}}"></icon> <icon class="weui-icon-checkbox_success" type="cancel" size="23" wx:if="{{item.checked}}"></icon> </view> <view class="weui-cell__bd">{{item.name}}</view> </label> </checkbox-group> </view> <view class="weui-btn-area"> <button class="weui-btn" style='background-color:#fff' plain="" type="default" bindtap="submit" disabled='{{submit}}'>提交错题</button> <button class="weui-btn weui_btn_primary" style='color:#fff;background-color:#33CC99' plain="" type="default" bindtap="submitAndAgain" disabled='{{submit}}'>再听一遍</button> </view> </view></view>

 pages/chooseBook/chooseLesson/detail/detail.js的代码如下:

const db = wx.cloud.database();const _ = db.command;let plugin = requirePlugin("WechatSI");let manager = plugin.getRecordRecognitionManager();const innerAudioContext = wx.createInnerAudioContext();let that;let i;let active;let oriSpeak;let oriContent;let book;Page({ data: { i: -1, sum: 99, userCollect: [], content: [], speak: [], steps: [], active: -1, show: true, submit: false }, // 文字转语音(语音合成) wordToSpeak: function (word) { let that = this; plugin.textToSpeech({ lang: "zh_CN", tts: true, content: word, success: function (res) { console.log(" tts", res) innerAudioContext.autoplay = true innerAudioContext.src = res.filename wx.showLoading({ // 提交时取消注释 mask: true, title: '正在播放', }) }, fail: function (res) { console.log("fail tts", res) } }) }, // 下一个 nextWord: function (e) { active = this.data.active; i = this.data.i; this.setData({ active: ++active, i: i+1 }); that.wordToSpeak(this.data.speak[i+1]); }, // 上一个 preWord: function (e) { i = this.data.i; i = this.data.i; if (i > 0) { this.setData({ active: --active, i: i - 1 }); that.wordToSpeak(this.data.speak[i-1]); } else { wx.showToast({ icon: 'none', title: '没有上一个了!', }) } }, // 重复 again: function (e) { i = this.data.i; if (i > -1) { that.wordToSpeak(this.data.speak[i]); } else { wx.showToast({ icon: 'none', title: '请先开始噢!', }) } }, onLoad: function (options) { oriSpeak = options.speak; oriContent = options.content; book = options.book; let content = []; let speak = []; let contentTemp = []; console.log(options); that = this; speak = options.speak.split('/'); speak.pop(); content = options.content.split('/'); content.pop(); this.setData({ sum: content.length, speak: (speak.length == 0 ? content : speak), steps: content }) for (let name of content) { let o = {}; o['name'] = name; o['value'] = name; contentTemp.push(o); } that.setData({ content: contentTemp }) innerAudioContext.onPlay(() => { console.log('开始播放') }) innerAudioContext.onError((res) => { if (res) { console.log(res) wx.hideLoading(), wx.showToast({ title: '文本格式错误', image: '/images/fail.png', }) } }) innerAudioContext.onEnded(function () { manager.start({ lang: "zh_CN" }) wx.hideLoading() }) }, checkboxChange: function (e) { console.log('checkbox发生change事件,携带value值为:', e.detail.value); var checkboxItems = this.data.content, values = e.detail.value; for (var i = 0, lenI = checkboxItems.length; i < lenI; ++i) { checkboxItems[i].checked = false; for (var j = 0, lenJ = values.length; j < lenJ; ++j) { if (checkboxItems[i].value == values[j]) { checkboxItems[i].checked = true; break; } } } this.setData({ content: checkboxItems, userCollect: e.detail.value }); }, submit: function () { this.setData({ submit: true }) wx.showLoading({ title: '提交中...', mask:true }) let userCollectID; if (that.data.userCollect) { db.collection('userCollectList').add({ data: { collect: that.data.userCollect, book: book, createTime: db.serverDate() }, success(res) { wx.hideLoading(); wx.showToast({ title: '提交成功!', duration: 3000, mask: true }) setTimeout(() => { wx.navigateBack({ }) }, 1000) } }) } else { wx.hideLoading(); wx.showToast({ title: '提交成功!', duration: 3000, mask: true }) setTimeout(() => { wx.navigateBack({ }) },1000) } }, submitAndAgain: function () { this.setData({ submit: true }) wx.showLoading({ title: '提交中...', mask: true }) let userCollectID; if (that.data.userCollect) { db.collection('userCollectList').add({ data: { collect: that.data.userCollect, book: book, createTime: db.serverDate() }, success(res) { wx.hideLoading(); wx.showToast({ title: '提交成功!', duration: 3000, mask: true }) setTimeout(() => { wx.redirectTo({ url: './detail?content=' + oriContent + '&speak=' + oriSpeak }) }, 300) } }) } else { wx.hideLoading(); wx.showToast({ title: '提交成功!', duration: 3000, mask: true }) setTimeout(() => { wx.redirectTo({ url:'./detail?content=' + oriContent + '&speak=' + oriSpeak }) }, 800) } }, onReady: function () {}, onShow: function () {}, onHide: function () {}, onUnload: function () { innerAudioContext.offPlay(); innerAudioContext.offEnded(); innerAudioContext.offError(); innerAudioContext.stop(); wx.stopBackgroundAudio(); manager.start({ lang: "zh_CN" }) wx.hideLoading() }, onPullDownRefresh: function () {}, onReachBottom: function () {}, onShareAppMessage: function () {}})

pages/chooseBook/chooseLesson/detail/detail.wxss的代码如下:

#detail { position: relative;}.weui-cell { width: 40%;}checkbox-group { display: flex; flex-wrap: wrap; justify-content: space-between;}.weui-cell__bd { white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}#detail .content-box { width: 80%; margin: 0 auto; margin-top: 220rpx; display: flex; align-items: center; flex-direction: row; flex-wrap: wrap;}#detail .content-box .content { font-size: 60rpx; margin: 0 20rpx; display: line-block;}.page__bd { margin-top: 90rpx; padding: 0 30px; text-align: left;}.icon-box{ margin-bottom: 80rpx; display: flex; align-items: center; border: 2px solid #FF9933; border-radius: 80rpx; box-shadow: 4px 4px 4px #ddd; background-color: rgba(255, 224, 51, 0.329); padding: 30rpx 20rpx; justify-content: center;}.icon-box__ctn{ flex-shrink: 100;}.icon-box__title{ font-size: 20px;}.icon { width: 250rpx; height: 250rpx; margin-right: 30rpx}

代码讲解

detail.js获取到chooseLesson.js传入的书本数据,利用微信同声传译插件提供的功能,调用wordToSpeak()函数实现文字转语音,并在该页面实现了上下切换和重复播放功能。

本文链接地址:https://www.jiuchutong.com/zhishi/298615.html 转载请保留说明!

上一篇:禁止网站被iframe嵌套的解决方法(网站禁止了有什么方法打开)

下一篇:Ai绘画工具有哪些?推荐这7款效果惊艳的AI绘画神器(ai绘图软件教程)

  • 微信号怎么修改(百度微信号怎么修改)

    微信号怎么修改(百度微信号怎么修改)

  • 浏览网页时遇到的最常见的网络广告形式是(浏览网页时遇到的最常见的网络警告形式是)

    浏览网页时遇到的最常见的网络广告形式是(浏览网页时遇到的最常见的网络警告形式是)

  • 屏幕hz代表什么意思(屏幕hz越高越好吗)

    屏幕hz代表什么意思(屏幕hz越高越好吗)

  • qq如何取消头像挂件(qq换不了头像怎么办?)

    qq如何取消头像挂件(qq换不了头像怎么办?)

  • 抖音名字前面的等级怎么来的(抖音名字前面的小星星是什么意思)

    抖音名字前面的等级怎么来的(抖音名字前面的小星星是什么意思)

  • 华为p40手机语音文件怎么录制(华为p40语音输入在哪)

    华为p40手机语音文件怎么录制(华为p40语音输入在哪)

  • 三星s10有AR测距仪功能吗(三星 测距)

    三星s10有AR测距仪功能吗(三星 测距)

  • 微博看别人视频有记录吗(微博看别人视频别人会看到浏览记录嘛)

    微博看别人视频有记录吗(微博看别人视频别人会看到浏览记录嘛)

  • 微信怎么看电脑有没有登录(微信怎么看电脑在线)

    微信怎么看电脑有没有登录(微信怎么看电脑在线)

  • qq截图快捷键ctrl加什么(qq截图快捷键ctrl加a用不了)

    qq截图快捷键ctrl加什么(qq截图快捷键ctrl加a用不了)

  • 在我国internet是指(internet在中国被称为什么)

    在我国internet是指(internet在中国被称为什么)

  • avi文件用啥打开(avi的文件)

    avi文件用啥打开(avi的文件)

  • 微信移出群聊有提示么(微信移出群聊还能看见消息吗)

    微信移出群聊有提示么(微信移出群聊还能看见消息吗)

  • 为什么哔咔无法注册(为什么哔咔无法下载最新版)

    为什么哔咔无法注册(为什么哔咔无法下载最新版)

  • 微信注销后多久生效(微信注销后多久显示已注销)

    微信注销后多久生效(微信注销后多久显示已注销)

  • 现在使用的计算机字长都是32位(现在使用的计算机的基本组成结构是由( )提出的)

    现在使用的计算机字长都是32位(现在使用的计算机的基本组成结构是由( )提出的)

  • 手机克隆二维码在哪里(手机克隆二维码怎么扫)

    手机克隆二维码在哪里(手机克隆二维码怎么扫)

  • 小红书ios怎么下载(小红书ios怎么下载视频)

    小红书ios怎么下载(小红书ios怎么下载视频)

  • 苹果怎么清理隐藏内存(苹果怎么清理隐藏灰色内存iPhone12)

    苹果怎么清理隐藏内存(苹果怎么清理隐藏灰色内存iPhone12)

  • 抖音怎么查到对方身份(抖音怎么查到对方真实信息)

    抖音怎么查到对方身份(抖音怎么查到对方真实信息)

  • 梯次电池是什么(梯次电池是什么电池)

    梯次电池是什么(梯次电池是什么电池)

  • 拼多多好友怎么看(拼多多好友怎么拉黑对方)

    拼多多好友怎么看(拼多多好友怎么拉黑对方)

  • 如何偷偷知道对方位置(如何偷偷知道对方的生日)

    如何偷偷知道对方位置(如何偷偷知道对方的生日)

  • 95开头号码如何拦截苹果手机(95开头属于什么号码)

    95开头号码如何拦截苹果手机(95开头属于什么号码)

  • 华为nova3相机设置(华为nova3拍照怎么显示日期时间)

    华为nova3相机设置(华为nova3拍照怎么显示日期时间)

  • 触宝电话如何显示本机号码(触宝电话怎么设置)

    触宝电话如何显示本机号码(触宝电话怎么设置)

  • 【深度学习】pix2pix GAN理论及代码实现与理解

    【深度学习】pix2pix GAN理论及代码实现与理解

  • 增值税进项税抵扣时间
  • 航天税务软件
  • 股东是否实缴出资款
  • 成本费用利润率反映什么
  • 房地产收入成本确认
  • 制作费发票明细怎么填
  • 房地产公司支付工程款账务处理
  • 核定征收企业可以申请高新技术
  • 房租收入如何缴税?
  • 工程分包开具发票怎么开
  • 工会专户收到职工福利经费会计处理怎么做?
  • 营改增后房地产企业增值税税率
  • 车辆购置税会计账务处理
  • 装卸搬运费是否含税
  • 个人销售货物缴纳增值税吗
  • 普票名称错了税号没错
  • 固定资产报废需要税务备案吗
  • 私账对私账不用交税吗
  • 小规模纳税人减免增值税会计处理
  • 人工费用占销售收入比重
  • 现代服务业如何提升为人民服务
  • 自产产品公益性捐赠可以免征增值税吗
  • 销项负数发票会计分录怎么写
  • 增值税季度不超过30万
  • 公司账上没车可以报车辆保险吗
  • 知道发票代码怎么查询发票号码
  • linux 如何查看网卡信息
  • 期间费用年末结转
  • php 混淆
  • php常用的技术栈
  • 财务收入怎么写
  • 预缴税款忘记抵扣
  • php判断ua
  • 企业向股东发放现金股利
  • 电商平台第三方服务
  • 应付票据开出票据的会计分录
  • 总部资产的减值有什么特点
  • 在建工程进项税额
  • thinkphp钩子场景
  • linux操作系统安装包
  • 挖机出租给公司
  • 应收账款确认无法收回
  • javascript手机编程
  • 检测费的税票税率怎么算
  • 宋大叔教音乐第三单元进阶版
  • 人工智能内容生成
  • phpcms怎么用
  • 视同销售的情况有哪些?
  • 自定义函数是啥
  • 出口退税转内销还是转免税好
  • 税控盘抵减增值税
  • 清税证明怎么在网上申请
  • 企业适用的增值税税率
  • 企业进行成本核算时,应根据生产经营特点
  • 补缴以前年度的印花税会计分录
  • 企业一般存款账户和基本存款账户的区别
  • 出口免税进项税怎么处理
  • 残保金属于职工社保吗
  • 资产负债表其他应收款计算公式
  • 小规模纳税人减按1%怎么计算
  • 补缴以前年度所得税及滞纳金账务处理
  • 销售折让的红字信息申请表怎么做
  • 营业外收入记入企业的什么
  • 支付的劳务派遣服务费计入什么科目
  • 个税和社保基数不一致怎么办
  • 如何在windows中添加字体
  • speedupmypc.exe - speedupmypc是什么进程
  • mac识别文字软件
  • 电脑开启虚拟wifi
  • win8免密码登录
  • windows7的安装步骤
  • css查找元素
  • 批处理删除指定后缀名
  • Node.js 中exports 和 module.exports 的区别
  • javascript 日期运算
  • java script
  • 土地增值税鉴证业务的流程
  • 日常生活中有哪些税
  • 改革开放四十年是几几年
  • 辽宁省耕地占用税适用税额表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设