主頁 > 前端設計 > 摸魚神器!開發效率提升 1000% 的 Vue 低代碼表單組件

摸魚神器!開發效率提升 1000% 的 Vue 低代碼表單組件

2021-09-29 08:13:28 前端設計

目錄:

  • 一、簡介
  • 二、本組件和 Element UI 的表單組件進行對比
  • 三、架構設計
  • 四、詳細功能描述
    • 4.1 wti-form 全域功能
    • 4.2 wti-form 表單元素功能
    • 4.3 如何一個 JSON 配置生成 3 個表單
  • 五、高度支持自動化測驗
    • 5.1 天生支持自動化測驗
    • 5.2 通過簡單的組態檔,自動完成自動化測驗
    • 5.3 更牛逼的自動化測驗支持
  • 六、未來將添加的功能
    • 6.1 可視化生成表單
    • 6.2 打通產品經理與前端這條線
    • 6.3 縱向拓展:自動生成后端代碼
    • 6.4 橫向拓展:表格、圖表的自動生成
  • 七、總結

一、簡介

作者:

零零水,曾寫過多個 10w+,1w+博客,前阿里巴巴前端開發,現為了 work life balance 于西安某信托國企做技術研發作業,擅長基于公司真實情況,做一些提高效率的優化,

另,從來不當標題黨,

描述

Vue.js 低代碼表單組件,基于 Element UI 二次開發而成,命名為 wti-form

組件高度封裝 js 邏輯的方式,是多表單頁面場景的大殺器,

目前支持的表單元素包括但不限于以下元素,如下圖:

04.png

更多支持的功能,見第一章節的結尾給的檔案鏈接

wti-form 特點:

痛點非~常~有~用~
表單太多,寫起來太煩用 json 來寫表單,ctrl + C, ctrl + V 做作業不是夢
討厭處理復雜場景的邏輯?內置支持各種一般場景和常見復雜場景
同一個表單,新增、編輯、查看寫 3 遍?一套代碼,可以通行【新增】、【編輯】、【查看】三種頁面,降低 70% 以上開發量
互動太多,除錯麻煩容易出出 bug?表單內部的互動已內聚,解耦表單和外部的互動,降低開發作業量
每個表單元素都要手寫太麻煩類 ElementUI 檔案,不僅詳細,并且每個示例后面都附代碼,直接 cv 就能用
我只會用 ElementUI基于 Element UI 封裝,支持大部分表單組件的原有屬性,并且比使用 ElementUI 更簡單
可靠否?已在公司內部穩定使用半年,完成表單頁數百個
需求太奇怪,現有組件不支持二次開發極其簡單,根據實際需求自主新增
我連代碼都不想寫檔案里內置一個配置器,配置好后,自動生成 vue 檔案,懶人福音
公司窮,開發水平菜上手特簡單,人員費用支出預計減少 50% 以上
表單測驗起來太麻煩了天生支持自動化測驗,并且從兩個方向支持自動化測驗!
其他開源!免費!如果是西安的國企,歡迎來公司進行技術交流

現在就開始試用!網頁上簡單配置,立刻預覽表單生成結果!

優點

  1. wti-form 可以極大的提高開發效率,預計最低提升效率 200%,最高提升效率 1000% 以上(都相對于使用 Element UI 來比);
  2. 檔案豐富詳細,有大量示例代碼,并且檔案本身已開源;
  3. 支持通過網頁配置,快速生成前端代碼(一整個 Vue 檔案)的功能(見檔案);
  4. 正在開發支持自動化測驗的組件,集成后,可以根據表單配置自動推斷并填寫表單元素(未來會開發 python 支持庫,方便集成進自動化測驗代碼里);

適用人群

  • 表單頁特別多,但人手/預算緊張的技術團隊;
  • 不擅長前端的后端開發者,但需要寫前端表單頁面(例如做私活);
  • 原本使用 Element UI ,但想減少重復作業量的開發者;
  • 一線開發人員水平層次不齊,想要提高初中級開發的代碼產出率、降低 bug 量的技術負責人;
  • 一般開發團隊(基于組件可以自定義值 UI 樣式);

github 和檔案地址:

  • 組件源代碼:https://github.com/qq20004604/wti-form
  • 檔案源代碼:https://github.com/qq20004604/wti-form-demo
  • 檔案地址:http://lovelovewall.com/wti_form_demo/home.html#/Install

二、本組件和 Element UI 的表單組件進行對比

因為是基于 Element UI 二次開發的,因此,必然要比使用 Element UI 進行開發更方便,功能更強大,否則沒有開發的價值,

因此,將本組件和 Element UI 進行對比,幫助你了解本組件的優勢,

附圖 1,圖中對于核心點已經高亮

02.png

目前表單組件支持的功能,附圖 2

04.png

三、架構設計

先附源代碼地址:https://github.com/qq20004604/wti-form/tree/main/package

上一個架構分層圖,附圖 3:

03.png

再上一個圖 4,組件事件流,

01.png

結合圖 3 和圖 4,總的來說,wti-form 的架構可以這么來理解:

  • 資料層:核心是【表單資料】和【配置資料】,而其他資料都是基于這 2 個動態計算出來的,并不會單獨存盤;
  • UI 層:根據配置資料動態生成 ui,因此假如傳入的配置變更,那么 ui 也會隨著動態變化;
  • 事件層:基于生成的 ui,用戶進行操作,則將觸發事件層,而事件層最終影響的是【表單資料】,

因此,整個組件,開發者只需要關心 2 個資料,以及基于資料衍生出來的 ui 和事件,因此并不存在同一個源資料但存盤于多處導致可能的沖突和一致性,因此可以輕松寫出高可靠度的代碼,

而基于這樣的設計,二次開發也是很簡單的一件事情了,

但因為篇幅所限(才怪,是因為我懶),因此上圖還缺少了這些:

  • 子表單的事件流,以及父表單與子表單的互動方法;
  • 表單與表單元素之間的關聯設計;
  • 基于個人需求,二次開發屬于自己的內部組件的方法;

四、詳細功能描述

4.1 wti-form 表單全域功能:

  • 通過 json 資料來生成表單;
  • 通過 data 資料給表單每個元素賦值;
  • 支持表單校驗;
  • 表單支持分塊顯示;
  • 支持單區塊收起、展開、全部收起、全部展開;
  • 支持將表單顯示模式切換:長表單/帶 tab 切換的短表單;
  • 支持表單元素全域禁用(例如提交時);
  • 支持給表單加一個外框,增加區分度;
  • 支持將表單模式切換為純文本顯示模式;
  • 支持設定表單為一行四列/兩列/一列;
  • 二次開發自定義表單元素難度極低;
  • 其他懶得寫了;

4.2 wti-form 表單元素功能:

  • 支持設定默認禁用、默認隱藏、默認值;
  • 支持設定必填;
  • 不同表單支持不同的校驗規則,也可以自定義校驗規則(同 Element UI);
  • 支持當某一個表單元素的值為指定值時,聯動設定另一個表單元素的值/設定隱藏/設定禁用/設定必填;
  • 支持自定義樣式;
  • 支持自定義 placeholder;
  • 支持文本輸入框、數字輸入框、金額輸入框、日期輸入框、日期范圍輸入框、動態下拉框(自動請求資料字典)、普通下拉框、時間輸入框、單選框、百分比輸入框、文本域輸入框等;
  • 其他懶得寫了;

4.3 一個 JSON 配置生成 3 個表單

再貼一遍圖 4:

01.png

也就是說,開發者一般來說只需要提供描述表單結構的 json,以及呼叫校驗方法,就可以完成一個完整的表單,

如果需要初始化資料(比如說表單編輯頁面),這個初始化資料和提交的資料結構是一模一樣的,

如果是需要查看內容(比如說是詳情查看頁),那么和編輯模式使用方法一樣,再將傳入組件的 text-model 這個值變為 true 即可(表示開啟純文本模式),在純文本模式下,即使是字典下拉框的介面,回傳的值是字典嗎,也會被自動翻譯成 label 的,

有人可能會有疑問,這樣的話,表單結構JSON 會不會很復雜?

當然不可能,具體可以參考檔案這個頁面:http://lovelovewall.com/wti_form_demo/home.html#/demo/Status
,你可以在打開這個頁面時,先試想一下自己實作這樣的功能(各種聯動、三個不同的表單再加互動功能),需要寫多少行代碼,

然后再看這個頁面的源代碼 https://github.com/qq20004604/wti-form-demo/blob/main/src/page/home/component/demo/status.vue

毫無疑問,本表單,至少減少了至少 80~90% 的開發作業量,所以標題中的提高 1000% 效率,并未夸張,只是單純陳述事實,

五、高度支持自動化測驗

5.1 天生支持自動化測驗

在測驗一個表單頁時,往往存在幾個常見難題:

  1. 表單太大,元素太多時:如果是手工測驗,每次要填寫很多表單項,非常浪費時間,如果是自動化測驗,那么要一個一個抓表單元素,然后給里面填值,也非常浪費時間;
  2. 表單太多:每個頁面都要寫一遍自動化測驗邏輯,很浪費時間;
  3. 表單元素變化:當表單要素變化時,要改自動化邏輯代碼,也很浪費時間;

所以,在面對大量表單頁場景時,往往測驗復雜度最少也是 O(n2),還很容易漏測,

針對這種情況,wti-form 對于支持自動化測驗,則非常友好,

5.1.1 表單元素定位

對于第一個問題,如果表單元素太多,我們需要一個快速定位每個元素的辦法,

對于這種情況,提供了一個解決方案:用一個唯一 class 來定位,

具體來說,假如下面是一個輸入框的 html

<div data-v-14c4e670="" data-v-74ae480c="" class="form-input-box form-item-box form-unqiue-name">
	<div data-v-14c4e670="" class="el-input el-input--suffix">
		<input type="text" autocomplete="off" placeholder="請輸入用戶名稱" class="el-input__inner">
	</div>
</div>

在我的設計里,每個元素,只要有 key,那么他必然有一個 class 是form-unqiue-${key},因此,可以通過這個唯一 class,找到頁面里的該元素,

因此,可以封裝一個類,通過入參 class 通過這個唯一 class 找到對應的表單元素,便可以獲取值\修改值,示例代碼如下:

class ElementManager:
    # 找到表單元素
    def findEle(self, key, type):
        ele = None
        if type == "input":
            ele = self.findInputEle(key)
        ## some other element type
        else:
            ele = self.findXXEle(key)
        return ele

    # 1、找到輸入框表單元素
    def findInputEle(self, key):
        ## find element and return
        pass

    # 找他各種表單元素(略)
    def findXXEle(self, key):
        pass

    # 設定元素的值
    def setVal(self, ele, type, val):
        pass

    # 獲取元素的值
    def getVal(self, ele, type):
        pass

使用的時候,只需要傳入元素的 key、型別(甚至可以不需要型別),就可以獲取到表單元素、獲取表單元素的值、設定表單元素的值,

無論需求怎么改,只需要改入參就可以了,于是,表單元素太多,需要一個一個獲取表達元素,增加測驗作業量的問題解決了,

5.2 通過簡單的組態檔,自動完成自動化測驗

基于 5.1 的方法,我們可以解決表單獲取元素的問題,

下來我們要面臨的就是如何進行各種測驗,例如必填的沒有填能否提交,有長度限制的過長或者過短能否通過校驗等,

于是,基于前端的 JSON 配置,通過寫一個工具類,我們可以通過每個表單元素的規則,自動推斷出其各種測驗場景的資料是什么,

如果能做到這一點,那么表單太多,寫測驗腳本麻煩的問題,也自然便解決了,

完成整個流程,基本沒有什么技術難度,如果不知道具體怎么實作的話,可以加我微信溝通,

5.3 更牛逼的自動化測驗支持

目前正在寫一個自動化測驗組件,效果是:

  • 將表單組件傳入到該組件中;
  • 該組件會自動根據 json 配置,和組件本身配置,推斷每個 key 應該生成什么樣的資料;
  • 目前支持三種資料:【標準合法資料】【合法邊界資料】【非法超限資料】;
  • 對于特殊的還支持用戶自定義資料生成;

但因為我懶,目前開發進度只有大約 10%(主要是領導也沒重視這玩意),只支持【文本輸入框】的資料生成,

具體可以參考檔案的這部分:http://lovelovewall.com/wti_form_demo/home.html#/others/AutoTest

六、未來將添加的功能

表單本身功能架構設計,已經比較完善了,二次開發新增更多表單元素型別,也不難,

因此,從表單開始,打通整個開發環節,可以更有效的提高開發效率,

6.1 可視化生成表單

與 C 端場景不同,B 端場景更常見是處理流程,一個流程里會有很多表單,而在這些表單里會有很多相同的表單元素,這就意味著,這些表單元素可以大量復用,

因此我們可以開發一個后端服務,專門用來存盤這些開發好的表單元素,

在開發一個新頁面時,可以通過關鍵詞搜索到之前寫好的表單元素,然后通過勾選/拖拽的模式,直接拖入表單,最后直接生成一個Vue 組件甚至頁面,這就是現在低代碼平臺最常見的使用方式了,

我們目前已經有這種方案的常規版本(比檔案里提供的版本更強),但是仍不夠完美,并不能泛用到所有表單里,

而本表單組件為什么可以稱為低代碼表單組件,也是通過這個來體現的,

不過,因為這個屬于公司業務代碼,因此無法直接給出來相關代碼和示例,

不過檔案里,給了一個【通過網頁直接生成表單】的功能,屬于基礎版,足夠一般開發使用,

http://lovelovewall.com/wti_form_demo/home.html#/demo/FastCreate

6.2 打通產品經理與前端這條線

在 5.1 中,我們還是單純只是前端代碼層面的東西,但對于現代開發,我們完全可以有更多想象,

表單做成什么樣子,是由產品經理定的,他們在把內容傳達給我們時,是要先搞一個 excel,描述表單這里每個元素的具體規則,

所以,我們能不能做一個工具,直接打通產品經理與前端開發呢,我覺得是完全可以的,

簡單設想一下,基于檔案里提供的【快速創建表單】提供的工具,我們再拓展一下,允許配置表單元素的規則,然后再基于這個生成一個 excel,那么這就是產品經理的要素表,

同時,我們將這個資料存盤到后端,然后前端可以基于這個,通過代碼生成工具(檔案里的 FastCreate 的功能),直接生成 Vue 檔案,

于是,并沒有增加產品經理的作業,甚至因為我們提供的工具,產品經理減少了他的作業量,也方便維護,

但同時,前端的作業量被大幅度減少了,前端只需要基于這個已經寫好的 Vue 檔案,二次開發一些特殊功能即可,

這就意味著,團隊對于前端開發的需求量,也許可以減少 50%以上,這帶來的都是研發成本的降低,

6.3 縱向拓展:自動生成后端代碼

當我們打通產品經理和前端時,毫無疑問,也可以打通產品經理和后端開發這條線,

基于當前設計,我們將表單和元素解耦后,完全可以預知這個頁面里,最后要提交給后臺的資料是什么樣子的,

換句話說,哪些元素必填、非必填、長度、型別,都是可以預知的,

而恰好,后端在表單校驗時,也是需要這些東西來校驗表單提交內容,因此,我們可以基于這個,直接生成后端的代碼,可以減少許多后端開發作業量,

因為是自動生成的,所以當產品經理更新他的需求后(表單元素),后端可以通過工具再次生成,而無需手動維護,

更重要的是,通過這種方法生成的前后端代碼,不會存在因為溝通問題,而導致欄位校驗規則不一致的情況,

毫無疑問,這也可以提高工程可靠性,

除此之外,還可以基于已有的 Excel、前端/后端代碼,做型別/資料推斷,在產品經理新增要素時,根據已有資料,智能猜測這個欄位的型別、規則等條件,

6.4 橫向拓展:表格、圖表的自動生成

一般來說,表單提交后,有時候需要通過表格、圖表來預覽,

所以在這種場景比較多的情況下,我們也可以基于穩定可靠的資料源,寫一個自動生成圖表、表格代碼的工具,

甚至,可以復用這個 json 配置,然后寫一個轉換函式,自動生成表格/圖表,

這個難度并不高,

七、總結

總而言之,wti-form,就使用難度、專業度、開發效率來說,完爆市面上大部分表單組件,并且不需要額外學習成本,

并且如果你目前已經在使用 ElementUI,那么使用本組件開發新表單,是毫無成本和風險的,

無論是接私活的后端開發者,成本有限人力不足天天加班的技術負責人,toB 場景需要寫大量表單頁面的中小軟體開發企業,都是最佳選擇,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/303896.html

標籤:其他

上一篇:Vuex中actions與map函式的總結(vuex摘要)

下一篇:HTML5+CSS+JavaScript實作捉蟲小游戲設計和實作【有密集恐懼癥的別玩喲】

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more