做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

在小程序中集成redux/immutable/thunk第三方庫的方法

來源:懂視網 責編:小采 時間:2020-11-27 22:10:12
文檔

在小程序中集成redux/immutable/thunk第三方庫的方法

在小程序中集成redux/immutable/thunk第三方庫的方法:一、前言 小程序給我們暴露了兩個參數 require 和 module , require 用來在模塊中加載其他模塊, module 用來將模塊中的方法暴露出去 module.exports = function(){} 所以只要需要讓第三方庫的代碼使用這種形式的 export 就可以了 二、構建Red
推薦度:
導讀在小程序中集成redux/immutable/thunk第三方庫的方法:一、前言 小程序給我們暴露了兩個參數 require 和 module , require 用來在模塊中加載其他模塊, module 用來將模塊中的方法暴露出去 module.exports = function(){} 所以只要需要讓第三方庫的代碼使用這種形式的 export 就可以了 二、構建Red

一、前言

小程序給我們暴露了兩個參數 require 和 module , require 用來在模塊中加載其他模塊, module 用來將模塊中的方法暴露出去

module.exports = function(){}

所以只要需要讓第三方庫的代碼使用這種形式的 export 就可以了

二、構建Redux的微信小程序包

打一個 Redux 包,讓它可以兼容微信小城的加載方式

git clone https://github.com/reactjs/redux.git

npm install

# 詳細內容可以到redux項目的package.json中查看
# 這些命令是是使用webpack構建UMD模式的包。也就是說所有的代碼,包括依賴的庫都會被打包到一個文件中,并且自帶一段模塊加載代碼,文件可以在dist目錄下找到
npm run build:umd && npm run build:umd

用編輯器打開 dist 目錄下的 redux.js 文件

(function webpackUniversalModuleDefinition(root, factory) {
 if(typeof exports === 'object' && typeof module === 'object')
 module.exports = factory();
 else if(typeof define === 'function' && define.amd)
 define([], factory);
 else if(typeof exports === 'object')
 exports["Redux"] = factory();
 else
 root["Redux"] = factory();
})(this, function() {
... 
})

這段代碼是用來加載模塊的,里面的factory函數的返回的內容是用webpack提供的loader組織起來的redux的代碼和第三方依賴。

  • 如果我們把這個文件拷貝到小程序中,只需要讓程序能正常進入第三行代碼,就能把Redux加載進來
  • 將第二行代碼: if(typeof exports === 'object' && typeof module === 'object') 修改成: if(typeof module === 'object')
  • 這樣修改的原因是,在微信小程序的環(huán)境中是沒有exports變量的,所以就沒辦法正確進入這個分支,刪除之后就可以正確進入
  • 我們拷貝到 libs 目錄下,那么我們在程序中使用時,只要當做是一個本地模塊去 require 就可以了 var redux = require('./libs/redux.js')
  • 我們可以通過類似的方法,使用 Webpack 打包第三方庫,就可以集成任何庫了
  • 三、集成Redux-devtools

    因為微信小程序的開發(fā)環(huán)境是定制的,暫時沒有發(fā)現辦法直接安裝 redux-devtool 的插件

    安裝remote-redux-devtools

    原版的 remote-redux-devtools 使用的一個 websocket 的依賴會使用原生的 WebSocket ,小程序是不支持的,所以需要改成小程序的 websocket 實現,修改好的代碼 https://github.com/poetries/wx-redux-immutable-template/blob/master/wx-redux-immutable-template/public/libs/remote-redux-devtools.js

    把代碼下載到工程目錄里面就可以用了

    安裝和啟動remotedev-server

    npm install -g remotedev-server
    remotedev --hostname=localhost --port=5678
    

    因為沒辦法用 npm 安裝到本地(微信小程序會嘗試去加載項目目錄中的所有js),所以這里使用全局安裝,第二條命令是啟動 remotedev-server , hostname 和 port 分別指定為 localhost 和 5678

    集成devtool

    在 store 下集成 devtool

    const {createStore, compose} = require('./libs/redux.js');
    const devTools = require('./libs/remote-redux-devtools.js').default;
    const reducer = require('./reducers/index.js')
    
    function configureStore() {
     return createStore(reducer, compose(devTools({
     hostname: 'localhost',
     port: 5678,
     secure: false
     })));
    }
    
    module.exports = configureStore;
    
    

    把 devtool 使用 redux 的 compose 加到 store 中去。 hostname 和 port 是指定為之前啟動 remotedev-server 啟動時候指定的參數。保存之后重啟一下小程序,如果沒有報錯的話就OK了

    可以在瀏覽器中訪問 localhost:5678

    四、小程序中集成immutable

    Immutable 是 Facebook 開發(fā)的不可變數據集合。不可變數據一旦創(chuàng)建就不能被修改,是的應用開發(fā)更簡單,允許使用函數式編程技術,比如惰性評估。微信小程序無法直接使用 Immutable.js ,下面就來說說微信小程序如何使用第三方庫 Immutable.js

    Immutable使用了UMD模塊化規(guī)范

    (function (global, factory) {
     typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
     typeof define === 'function' && define.amd ? define(factory) :
     (global.Immutable = factory());
    }(this, function () { 'use strict';var SLICE$0 = Array.prototype.slice;
    
    ....
    
    }));
    
    

    修改 Immutable 代碼,注釋原有模塊導出語句,使用 module.exports = factory() 強制導出

    (function(global, factory) {
     /*
     typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
     typeof define === 'function' && define.amd ? define(factory) :
     (global.Immutable = factory());
     */
    
     module.exports = factory();
    
    }(this, function() {
    

    導入修改好的 immutable 到小程序中即可 https://github.com/poetries/wx-redux-immutable-template/blob/master/wx-redux-immutable-template/public/libs/immutable.js

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    在小程序中集成redux/immutable/thunk第三方庫的方法

    在小程序中集成redux/immutable/thunk第三方庫的方法:一、前言 小程序給我們暴露了兩個參數 require 和 module , require 用來在模塊中加載其他模塊, module 用來將模塊中的方法暴露出去 module.exports = function(){} 所以只要需要讓第三方庫的代碼使用這種形式的 export 就可以了 二、構建Red
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 镇坪县| 雷山县| 寿阳县| 苍南县| 张家界市| 泽普县| 岳阳县| 长丰县| 馆陶县| 盈江县| 武宣县| 文化| 樟树市| 夏河县| 济源市| 合作市| 大连市| 宣化县| 滦平县| 方山县| 贵南县| 台山市| 金塔县| 夏邑县| 东台市| 同心县| 商水县| 台江县| 清镇市| 盘锦市| 开江县| 侯马市| 增城市| 重庆市| 益阳市| 海门市| 湖南省| 日喀则市| 安仁县| 胶南市| 犍为县|