摘要:做題區(qū)域自動(dòng)補(bǔ)全剩下的高度代碼如下時(shí)間轉(zhuǎn)換的函數(shù)由秒轉(zhuǎn)換的格式時(shí)間轉(zhuǎn)換測(cè)試網(wǎng)址點(diǎn)我跳轉(zhuǎn)手機(jī)打開或?yàn)g覽器仿真?zhèn)}庫地址鏈接有用記得點(diǎn)個(gè)星掃碼也可以上幾張效果圖
實(shí)現(xiàn)功能:
題目的加載
文章的上下滑動(dòng)
做題模式
做題內(nèi)容區(qū)域的上下滑動(dòng)動(dòng)態(tài)調(diào)整做題區(qū)域
左右滑動(dòng)切換題目
計(jì)時(shí)功能
提交限制功能
字體大小調(diào)節(jié)
背景顏色調(diào)節(jié)
網(wǎng)絡(luò)錯(cuò)誤提示窗
做題選中邏輯
首先遇到的問題是做題區(qū)域與文章區(qū)域上下滑動(dòng)的問題
怎樣才能自適應(yīng)屏幕呢
首先在 created函數(shù)里,獲取當(dāng)前屏幕的高度
this.clientHeight = document.documentElement.clientHeight this.position = this.clientHeight / 2 this.positionEnd = this.clientHeight / 2
后來經(jīng)過多方面調(diào)研,發(fā)現(xiàn)沒有適合的分屏插件
于是決定自己寫截屏插件
大體思路如下
利用touch.js來偵測(cè)手指在屏幕中的滑動(dòng)事件
根據(jù)獲得的參數(shù),計(jì)算出做題區(qū)域與文章展示區(qū)域的高度變化
根據(jù)高度變化,改變文章顯示區(qū)域的高度。做題區(qū)域自動(dòng)補(bǔ)全剩下的高度
代碼如下
onPanup (e) { this.aniM = false console.log(this.clientHeight - this.position) if (this.clientHeight - this.position <= 200) { this.position = this.clientHeight - 200 this.contentHeight = this.position + "px" return false } else { this.position = e.deltaY + this.positionEnd this.contentHeight = this.position + "px" let child = document.getElementsByClassName("setHeight") if (this.examStatus) { for (var i = 0; i < child.length; i++) { child[i].setAttribute("style", "padding-bottom:50px;height:" + (this.clientHeight - this.position - 100) + "px") } } else { for (var j = 0; j < child.length; j++) { child[j].setAttribute("style", "height:" + (this.clientHeight - this.position - 80) + "px") } } } },
setH () { let child = document.getElementsByClassName("setHeight") if (this.examStatus) { for (var i = 0; i < child.length; i++) { child[i].setAttribute("style", "padding-bottom:50px;height:" + (this.clientHeight - this.position - 100) + "px") } } else { for (var j = 0; j < child.length; j++) { child[j].setAttribute("style", "height:" + (this.clientHeight - this.position - 80) + "px") } } },
onPanend (e) { if (this.clientHeight - this.position <= 200) { this.position = this.clientHeight - 201 this.positionEnd = this.clientHeight - 201 } else { this.positionEnd = this.positionEnd + e.deltaY } },
時(shí)間轉(zhuǎn)換的函數(shù)
由秒轉(zhuǎn)換XX:XX的格式
startTime () { this.startTimeTop ++ this.timeTrans(this.startTimeTop) setTimeout(() => { this.startTime() }, 1000) }, // 時(shí)間轉(zhuǎn)換 timeTrans (val) { let f = parseInt(val / 60) let m = val % 60 if (f < 10) { f = "0" + f } if (m < 10) { m = "0" + m } this.time.f = f this.time.m = m },
測(cè)試網(wǎng)址點(diǎn)我跳轉(zhuǎn)(手機(jī)打開或?yàn)g覽器仿真)
github倉庫地址git鏈接
https://github.com/fanshyiis/...
有用記得點(diǎn)個(gè)星
https://www.enjoyreading.net/...
掃碼也可以
上幾張效果圖
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/93416.html
摘要:做題區(qū)域自動(dòng)補(bǔ)全剩下的高度代碼如下時(shí)間轉(zhuǎn)換的函數(shù)由秒轉(zhuǎn)換的格式時(shí)間轉(zhuǎn)換測(cè)試網(wǎng)址點(diǎn)我跳轉(zhuǎn)手機(jī)打開或?yàn)g覽器仿真?zhèn)}庫地址鏈接有用記得點(diǎn)個(gè)星掃碼也可以上幾張效果圖 實(shí)現(xiàn)功能: 題目的加載 文章的上下滑動(dòng) 做題模式 做題內(nèi)容區(qū)域的上下滑動(dòng)動(dòng)態(tài)調(diào)整做題區(qū)域 左右滑動(dòng)切換題目 計(jì)時(shí)功能 提交限制功能 字體大小調(diào)節(jié) 背景顏色調(diào)節(jié) 網(wǎng)絡(luò)錯(cuò)誤提示窗 做題選中邏輯 首先遇到的問題是做題區(qū)域與文章區(qū)域上下...
摘要:目前,常用的模塊規(guī)范主要有兩種和。攔截全局請(qǐng)求一直接引入腳本攔截需要的回調(diào)或函數(shù)。深刻知道一個(gè)良好的命名規(guī)范的重要性,同時(shí)在項(xiàng)目中也會(huì)遇到一些命名的瓶頸。 基于 Three.js 的超快的 3D 開發(fā)框架:Whitestorm.js Whitestorm.js 是一款基于 Three.js 超快的 Web 應(yīng)用 3D 開發(fā)框架。它為普通的 Three.js 任務(wù)提供封裝、使搭建環(huán)境、...
閱讀 1947·2021-11-23 09:51
閱讀 1252·2019-08-30 15:55
閱讀 1625·2019-08-30 15:44
閱讀 771·2019-08-30 14:11
閱讀 1153·2019-08-30 14:10
閱讀 922·2019-08-30 13:52
閱讀 2641·2019-08-30 12:50
閱讀 625·2019-08-29 15:04