精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何快速將你的應用封裝成JS-SDK?

開發 前端
本文將介紹前端如何封裝一款 js-sdk 以及如何快速將你的應用變成 js-sdk , 我們將總結一些封裝 js-sdk 的原則和案例, 來幫大家更快的上手 sdk 開發.

 前言

本文將介紹前端如何封裝一款 js-sdk 以及如何快速將你的應用變成 js-sdk , 我們將總結一些封裝 js-sdk 的原則和案例, 來幫大家更快的上手 sdk 開發. 其中筆者還會以H5-Dooring 為例子, 介紹如何將 H5 頁面編輯器封裝成一個 js-sdk 供他人使用.

正文

在開始文章之前, 筆者先來介紹一下什么是 sdk .

sdk 即軟件開發工具包, 一般是一些軟件工程師為特定的軟件包、軟件框架、硬件平臺、操作系統等建立應用軟件時的開發工具的集合。

對于 js-sdk 而言, 我們能舉出很多例子, 如下:

  • UI組件庫
  • 性能監控工具, 如阿里 arms
  • 統計分析工具
  • 阿里云智能驗證sdk
  • 極驗驗證sdk

sdk 的目的是提高我們開發項目的效能, 安全性和便捷性等問題, 所以我們在設計 sdk 時一定要遵循一些原則, 如下: 

 

  • 最小可用性原則: 也就是沒有必要的功能/代碼盡量不額外添加, 使代碼達到最簡
  • 最少依賴原則: 也就是沒有必要的依賴堅決不添加, 以達到最低限度的外部依賴
  • 易擴展: 插件化,最大限度支持擴展和自定義
  • 穩定性: 絕不能導致宿主應用崩潰,向后兼容, 可測試

在熟悉以上的背景和原則之后, 我們來看看如何實現一個 sdk 的案例.

將 H5-Dooring 封裝成一個 js-sdk

筆者在這拿 開源頁面制作工具 H5-Dooring 來作為案例(當然將其封裝成 sdk 也是我們迭代中的一部分, 甚至后期會做成npm包), 介紹如何封裝js-sdk, 我們先看一張抽象圖:


我們的 sdk 就好像一個完整系統的一個零件, 可以和系統中的其他模塊通信, 互相交換數據. 總體而言 sdk 是為宿主系統服務的, 在 dooring-sdk 中 我們一方面要提供對外的接口支持, 另一方面需要支持宿主能控制 H5 編輯器的界面, 所以綜合分析下來我們有如下的初步規劃圖:


首先我們 sdk 采用 js 動態加載 iframe 的模式來實現, 并通過 iframe 通信來實現props 傳遞, 此時可以有兩種比較靠譜的通信方案:

  • 使用 postmessage 實現跨域跨系統通信
  • 使用 url 參數通信

由于 postmessage 對宿主系統要求比較高, 需要宿主手動配置 origin 白名單, 對可插拔式體驗不夠友好, 所以筆者這里采用了比較常用的 url 通行方式, 這里需要對參數做解析, 最后達到一個比較簡單的接入方式, 如下:

  1. var dooringOpts = { 
  2.     container: '',  // 掛載到哪個dom節點上 
  3.     iframeStyle: {  // iframe自定義樣式 
  4.         width: ''
  5.         height: ''
  6.         border: '' 
  7.     }, 
  8.     controls: { 
  9.       gallery: false,  // 是否啟動圖片庫 
  10.       template: false, // 是否啟用模版庫 
  11.       saveTemplate: true,  // 參數可以是true/false,表示是否啟動下載代碼, 也可以是函數, 用來自定義下載代碼邏輯 
  12.       save: true,  // 參數可以是true/false,表示是否啟動下載代碼, 也可以是函數, 用來自定義下載代碼邏輯 
  13.       downCode: true, // 參數可以是true/false,表示是否啟動下載代碼, 也可以是函數, 用來自定義下載代碼邏輯 
  14.       isPhoneTest: false
  15.       helpPage: true,   // false/true表示隱藏/顯示幫助頁面 
  16.       uploadApi: '',  // 自定義上傳api 
  17.       formApi: '',  // 自定義表單提交api 
  18.       screenshotsApi: ''  // 自定義截圖提交api 
  19.     } 

用戶只需要在全局定義好配置的 props 和 callback , 即可自由定制 H5-Dooring. 接下來我們只需要再引入 dooring-sdk即可(注意先定義全局變量, 再引入sdk):

  1. <script src="http://49.234.61.19/dooring-sdk.js"></script> 

以上只是確定了 js-sdk 的方案和最終調用效果, 接下來我們來看看如何去實現它. 也就是 dooring-sdk 內部到底做了那些工作. 我們先看一張實現機制圖:

由上圖分析可知我們需要提前把用戶定義的全局配置解析成 url 參數, 然后將動態創建的 iframe 的 src 屬性設置為 dooring url + parmas的結構, 具體實現如下:

  1. (function(){ 
  2.       let iframe = document.createElement('iframe'); 
  3.       let tid = Date.now(); 
  4.       let sdk_domain_path = 'http://xxxx/xxxx'
  5.       iframe.src = sdk_domain_path + '/h5_plus/editor?tid=' + tid + '&' + getDooringApiStr(dooringOpts) + '&isOpen=1'
  6.  
  7.       iframe.style.border = 'none'
  8.       iframe.style.width = '100vw'
  9.       iframe.style.height = '100vh'
  10.       if(dooringOpts && dooringOpts.iframeStyle) { 
  11.           iframe.style.border = dooringOpts.iframeStyle.border || 'none'
  12.           iframe.style.width = dooringOpts.iframeStyle.width || '100vw'
  13.           iframe.style.height = dooringOpts.iframeStyle.height || '100vh'
  14.       } 
  15.  
  16.       document.querySelector(dooringOpts.container || 'body').appendChild(iframe); 
  17.  
  18.       function getDooringApiStr(opt) { 
  19.           let controls = Object.assign({ 
  20.               gallery: false
  21.               template: false
  22.               saveTemplate: true,  // 參數可以是true/false,表示是否啟動下載代碼, 也可以是函數, 用來自定義下載代碼邏輯 
  23.               save: true,  // 參數可以是true/false,表示是否啟動下載代碼, 也可以是函數, 用來自定義下載代碼邏輯 
  24.               downCode: true, // 參數可以是true/false,表示是否啟動下載代碼, 也可以是函數, 用來自定義下載代碼邏輯 
  25.               isPhoneTest: false
  26.               helpPage: true,   // false/true表示隱藏/顯示幫助頁面 
  27.               uploadApi: ''
  28.               formApi: ''
  29.               screenshotsApi: '' 
  30.           }, opt.controls || {}) 
  31.  
  32.           let params = ''
  33.           for(let key in controls) { 
  34.               params += key + '=' + encodeURI(controls[key]) + '&' 
  35.           } 
  36.           return params.slice(0, params.length -1) 
  37.       } 
  38. })() 

以上只是個簡單的實現實現思路, 是不是有點傳統的寫jquery插件的感覺? 同時我們還需要配合 h5-dooring 內部去支持解析 parmas 等操作, 這里感興趣的可以自行研究. 當然 sdk 的實現方式還有很多, 期待大家的探索.

最后

以上方案筆者已經集成到 H5-Dooring 中,大家可以以 sdk 的方式體驗一下。github 地址:所見即所得的H5頁面編輯器H5-Dooring

 

責任編輯:姜華 來源: 趣談前端
相關推薦

2015-02-12 16:57:35

微信SDK

2015-02-12 17:48:54

微信SDK

2015-02-12 17:23:33

微信SDK

2015-02-12 17:28:23

微信SDK

2015-01-13 13:57:52

2021-04-30 17:35:16

前端開發技術熱點

2015-01-28 00:35:00

2023-05-10 09:24:10

TypeScript工具

2011-03-30 14:31:25

Mssql數據庫

2021-06-07 19:26:50

WindowsDocker工作站

2009-09-08 17:45:13

Ophone Widg

2023-06-19 09:01:17

2013-03-26 14:45:21

HTML5封裝成and

2012-11-23 17:20:43

Linux服務器

2019-12-20 14:10:19

Python腳本語言工具

2020-11-25 10:42:57

Python代碼工具

2017-05-10 16:09:12

MySQL數據庫查詢

2014-09-01 09:49:24

github

2022-05-11 17:21:05

Btrfs文件系統Fedora

2021-08-31 08:32:40

開源項目開發
點贊
收藏

51CTO技術棧公眾號

电影在线一区| 国产黄色免费观看| 95精品视频| 亚洲激情av在线| 国内精品视频在线播放| 亚洲av无码不卡| 亚洲午夜精品一区 二区 三区| 日韩欧美成人激情| 成年人黄色片视频| caopeng在线| 久久综合精品国产一区二区三区| 国产精品美女在线观看| 午夜69成人做爰视频| 亚洲精品国产setv| 国产成人免费av在线| 久久久亚洲天堂| 国产又大又粗又爽的毛片| 国产精品麻豆| 91黄色在线观看| 成人在线观看毛片| 国产系列在线观看| 粉嫩一区二区三区在线看| 国产精品av电影| 精品无码m3u8在线观看| 欧美日韩精品一区二区视频| 精品免费一区二区三区| 日本激情视频在线播放| 国产极品在线观看| 亚洲精品欧美专区| 先锋影音一区二区三区| 天天干,天天操,天天射| 国产精品hd| 尤物精品国产第一福利三区| 超碰caoprom| 精品久久久久久久久久岛国gif| 色综合欧美在线视频区| 国产 欧美 日本| 中文字幕在线播放| 国产肉丝袜一区二区| 好看的日韩精品视频在线| 国产情侣av在线| 麻豆国产精品视频| 国产精品久久久久久久天堂| 日韩不卡视频在线| 国一区二区在线观看| www欧美日韩| ass极品国模人体欣赏| 欧美亚洲国产日韩| 日韩电影中文字幕在线| 人妻精油按摩bd高清中文字幕| 成人国产一区| 欧美性一二三区| 青青草原成人网| 爱情岛亚洲播放路线| 尤物av一区二区| 成人一区二区av| 国产理论在线观看| 亚洲另类春色国产| 欧美少妇一区二区三区| 成人av福利| 亚洲免费观看高清完整版在线| 最新欧美日韩亚洲| 成人午夜在线影视| 亚洲在线中文字幕| 奇米影视亚洲色图| 色视频免费在线观看| 成人97人人超碰人人99| 国产精品久久激情| 无码免费一区二区三区| 三级欧美在线一区| 欧美裸体男粗大视频在线观看| 一本在线免费视频| 午夜国产一区二区| 久热国产精品视频| 亚洲精品视频久久久| 人体久久天天| 亚洲视频一区二区| 国产馆在线观看| 香蕉视频官网在线观看日本一区二区| 久久精品一本久久99精品| 成年人午夜剧场| 亚洲欧美综合久久久| 欧美第一页在线| 国产一卡二卡在线播放| 亚洲一区欧美激情| 国产精品亚洲精品| 91香蕉在线视频| 国产一区91| 国产精品久久久久77777| 亚洲永久精品视频| 成人精品国产福利| 日韩精品久久久免费观看| 麻豆视频在线播放| 亚洲国产一区二区三区| 黑鬼大战白妞高潮喷白浆| 国产黄色一区| 精品福利视频一区二区三区| 波多野结衣办公室33分钟| 一区三区自拍| 亚洲国产一区二区三区四区| 天天躁夜夜躁狠狠是什么心态| 欧美国产美女| 97视频免费在线观看| 九九热最新视频| 高清日韩电视剧大全免费| 欧美日本韩国在线| 色操视频在线| 欧美在线观看一二区| 1314成人网| 极品美女一区二区三区| 九九九热精品免费视频观看网站| av大片在线免费观看| 国产一区二区三区四区五区入口| 久久精品一二三区| av黄色在线| 91久久精品一区二区三| aaa黄色大片| 色喇叭免费久久综合网| 国产91精品久久久久久久| 国产大片aaa| 理论片日本一区| 久久综合精品一区| 牛牛精品在线| 性做久久久久久免费观看| 五月婷婷激情久久| 神马日本精品| 欧美激情手机在线视频| 91丨porny丨在线中文 | 国产精品国产三级国产aⅴ入口 | 岛国视频一区| 免费高清完整在线观看| 色999日韩国产欧美一区二区| 天堂va欧美va亚洲va老司机| 欧美电影《睫毛膏》| 国产91久久婷婷一区二区| 午夜av免费在线观看| 一区二区三区在线观看动漫| 一级片视频免费观看| 久草成人在线| 国产一级揄自揄精品视频| 精品爆乳一区二区三区无码av| 美女一区二区久久| 五码日韩精品一区二区三区视频| 最新欧美色图| 91福利小视频| 一区二区三区免费在线观看视频| 亚洲成人在线| 欧美一级淫片丝袜脚交| 日批免费在线观看| 亚洲五码中文字幕| 动漫av在线免费观看| 欧美日韩精品一本二本三本 | 久久久精品中文字幕| 中文字幕在线观看精品| 国产精品人人做人人爽人人添| 天天操天天爱天天爽| 日韩国产一区| 91九色综合久久| h视频在线免费观看| 欧美变态凌虐bdsm| 国产无遮挡免费视频| 99re热这里只有精品视频| 一女被多男玩喷潮视频| 九色精品国产蝌蚪| 国产精品夜间视频香蕉| av在线天堂| 欧美精品欧美精品系列| 三级在线观看免费大全| 国产精品久久久久久久久久妞妞| 成人xxxxx色| 黄色片在线看| 在线看不卡av| 午夜激情福利网| 国产精品一卡二卡在线观看| 嫩草影院中文字幕| 特黄特色欧美大片| 国产精品9999| 老司机福利在线视频| 精品久久国产字幕高潮| 精品人妻一区二区三区免费看| 国产视频在线观看一区二区三区| 91欧美视频在线| 欧美久久九九| 欧美精彩一区二区三区| 欧美v亚洲v综合v国产v仙踪林| 美女撒尿一区二区三区| 进去里视频在线观看| 99在线视频精品| 91黄色小网站| 天堂美国久久| 国产一区精品在线| 视频精品导航| 久久久久中文字幕2018| 国产在线高清| 欧美一二三四区在线| 欧美激情亚洲综合| 最新日韩av在线| 日本丰满少妇裸体自慰| 精品亚洲国内自在自线福利| 日韩精品在线观看av| 麻豆一二三区精品蜜桃| 91国产美女视频| 欧美精品电影| 亚洲精品美女网站| 国产女人高潮毛片| 日本韩国一区二区| 久久免费在线观看视频| 国产性色一区二区| zjzjzjzjzj亚洲女人| 捆绑调教一区二区三区| 日韩黄色片视频| 欧美成人一品| 亚洲电影一二三区| 欧美电影在线观看免费| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 亚洲国产精品女人久久久| 国产精品无码粉嫩小泬| 亚洲一区二区三区四区在线| avhd101老司机| 日韩国产在线观看一区| 大西瓜av在线| 亚洲久久久久| 亚洲精品国产精品国自产观看| 国产精品宾馆| 91精品国产99| 性欧美videos高清hd4k| 最近更新的2019中文字幕| 亚洲av电影一区| 日韩你懂的在线观看| 中文字幕一区二区人妻痴汉电车| 黄色一区二区在线| 久久国产在线视频| 亚洲日本va在线观看| 91社区视频在线观看| 久久久精品黄色| 亚洲精品在线视频免费观看| 国产超碰在线一区| 三级av免费看| 极品少妇xxxx偷拍精品少妇| 亚洲国产精品三区| 日韩不卡一区二区三区| 丰满少妇大力进入| 国语对白精品一区二区| 人人妻人人澡人人爽欧美一区双 | 91麻豆福利精品推荐| 日本少妇xxxx| 不卡一区在线观看| 日本国产在线视频| 播五月开心婷婷综合| 韩国三级在线看| 国产不卡一区视频| japanese在线观看| 91视视频在线直接观看在线看网页在线看| 第一页在线视频| 丁香另类激情小说| 一级黄色电影片| 成人高清av在线| 99久久国产精| 国产午夜亚洲精品不卡| 人妻视频一区二区| 国产精品国产a| av激情在线观看| 一区二区久久久久久| 国产亚洲欧美精品久久久www| 亚洲国产精品尤物yw在线观看| 日本三级理论片| 国产亚洲欧美色| 1024手机在线观看你懂的| 国产精品萝li| 日韩视频中文字幕在线观看| 一区二区三区国产精品| 日本a在线观看| 欧美日韩一二三四五区| 午夜剧场免费在线观看| 依依成人综合视频| 精品成人av一区二区在线播放| 日韩人在线观看| 一区二区精品视频在线观看| 91精品国产综合久久小美女| 亚洲精品国产suv一区| 亚洲欧美国产精品久久久久久久| 成人免费在线观看| 久久综合色88| 亚洲一区资源| 国产主播在线一区| 成人三级av在线| 日韩高清av| 欧美va天堂| 女性隐私黄www网站视频| 国产在线精品一区二区不卡了| 日韩黄色一区二区| 国产日韩欧美一区二区三区乱码| 欧美一区免费观看| 一本到三区不卡视频| 国产精品国产av| 亚洲欧美自拍一区| 18av在线播放| 国产精品久久久久久久久久尿| 亚洲国产中文在线二区三区免| 欧美少妇一区| 在线精品福利| 久久久久久久久久久久久久久国产| 狠狠色综合播放一区二区| 天堂久久久久久| 亚洲乱码一区二区三区在线观看| 麻豆久久久久久久久久| 欧美一区二区三区思思人 | 在线午夜精品自拍| 福利在线导航136| 国产精品久久久久久久久久久久 | 国产一区二区精品久久99| 亚洲久久久久久| 亚洲男人天堂av网| 亚洲精品久久久久久久蜜桃| 精品国产亚洲在线| 伊人免费在线| 中文字幕久久久av一区| 国产探花视频在线观看| 国产欧美一区二区| 亚洲精品456| 国产96在线 | 亚洲| 国产一区二区三区在线看麻豆| 亚洲欧美va天堂人熟伦| 欧美性xxxxxxxxx| 欧美熟妇交换久久久久久分类| 久久精品国产精品亚洲| 91国拍精品国产粉嫩亚洲一区| 久久er99热精品一区二区三区| 国产一区观看| 秋霞午夜鲁丝一区二区| 亚洲欧美综合另类在线卡通| 羞羞色院91蜜桃| 亚洲精品一区av在线播放| av白虎一区| 99精品国产高清在线观看| 888久久久| 午夜一区二区视频| 亚洲国产高清在线| 亚洲欧美一二三区| 亚洲欧美日韩在线一区| 成人av三级| 蜜桃视频在线观看成人| 亚洲精品美女91| 无码日韩人妻精品久久蜜桃| av中文字幕亚洲| 九热这里只有精品| 精品日韩在线观看| 成人免费一区二区三区牛牛| 99精品国产高清在线观看| 欧美一区激情| 免费欧美一级片| 亚洲综合在线观看视频| 成 人 黄 色 片 在线播放| 欧美成人黄色小视频| 天堂va在线高清一区| 嫩草影院中文字幕| 99久久精品久久久久久清纯| 亚洲日本韩国在线| 亚洲视频在线观看| 四虎影视成人精品国库在线观看| 亚洲精品日韩精品| 国产最新精品免费| 美女毛片在线观看| 日韩经典第一页| 亚洲综合在线电影| 一区二区三区三区在线| 国产欧美日韩一区二区三区在线| 欧洲一级黄色片| 欧美亚洲高清一区二区三区不卡| 在线播放麻豆| 2019国产精品视频| 日韩一区二区久久| 国产中年熟女高潮大集合| 欧美日韩在线一区二区| 高清全集视频免费在线| 精品国产乱码久久久久软件| 久久婷婷久久| 大地资源高清在线视频观看| 欧美一区二区福利在线| 岛国av在线播放| 五月天国产一区| 国产成人免费视频精品含羞草妖精| 在线观看精品国产| 夜夜嗨av色一区二区不卡| 国产区一区二| 日本网站免费在线观看| 国产精品乱码一区二区三区软件 | 成人网中文字幕| 欧美精品日本| 久久久久久久久久久久| 欧美军同video69gay| 久久五月精品中文字幕| 蜜桃免费一区二区三区| 韩国一区二区三区| 国产超碰人人爽人人做人人爱| 色噜噜狠狠狠综合曰曰曰| 亚洲性视频在线| 久久精品免费网站| 亚洲一区二区在线播放相泽| melody高清在线观看|