国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

淺談webpack下的AOP式無侵入注入

2019-11-19 14:56:52
字體:
來源:轉載
供稿:網友

說起來, 面向切面編程(AOP)自從誕生之日起,一直都是計算機科學領域十分熱門的話題,但是很奇怪的是,在前端圈子里,探討AOP的文章似乎并不是多,而且多數拘泥在給出理論,然后實現個片段的定式)難免陷入了形而上學的尷尬境地,本文列舉了兩個生產環境的實際例子論述webpack和AOP預編譯處理的結合,意在拋磚引玉。當然,筆者能力有限,如果有覺得不妥之處,還請大家積極的反饋出來, 共同進步哈。

重要的概念

AOP: 面向切面編程,通過預編譯方式和運行期動態代理實現程序功能的統一維護的一種技術。

Joint point:表示在程序中明確定義的點,典型的包括方法調用,對類成員的訪問以及異常處理程序塊的執行等等,它自身還可以嵌套其它 joint point。

Advice:Advice 定義了在 pointcut 里面定義的程序點具體要做的操作,它通過 before、after 和 around 來區別是在每個 joint point 之前、之后還是代替執行的代碼。

通過前面的定義,我們可以提煉出一句更簡單的定義,利用靜/動態的方式使代碼塊在何時/何地運行。

性能統計

項目的背景是一個利用vue+webpack打造的多頁面應用 (多入口點),她的結構大概是這個樣子的

var baseConf = {// code hereentry: {index: 'src/index',list: 'src/list',detail: 'src/detail',// and so on ...},// code here}

然后以index入口點舉例,大概代碼為src/index/index.js

import Vue from 'vue'import App from './app'new Vue({el: '#app',render: h => h(App)})

期望引入一個vue插件,能夠自動的監控當前頁面的性能,于是,代碼看起來像是這個樣子

import Vue from 'vue'Vue.use(performance) //性能統計import App from './app'new Vue({el: '#app',render: h => h(App)})

由于這種方式意味著每個入口點均需要進行修改,(實際上這個項目的入口點超過30個,而且隨時可能繼續增加下去)簡直就是一個體力活。所以,讓我們用AOP的思想來考慮一下如何處理這個問題

首先觀察入口點邏輯

原:引入vue -> 引入app組件 -> 實例化vue組件

新:引入vue -> 應用性能統計組件 -> 引入app組件 -> 實例化vue組件

套用到我們的定義上,可以輕松的得到

Joint point(何處) 引入vue

advice(何時) 之后

這樣理論上的東西似乎閉著眼睛都可以推論出來,但是如何將這樣的步驟替換到每一個入口點就是一個大問題了orz。幸運的是這是一個import,而翻閱webpack的文檔恰好有著這樣一個神奇的屬性--alias

resolve: {alias: {'vue$': resolve('src/vueHook.js')}

src/vueHook.js

import vue from 'vue/dist/vue.common'vue.use(performance)export default vue

這樣,我們就完成了一個vue的全局鉤子模塊,我們按照步驟歸納,并且找到注入的位置 ,最后利用替換的方式成功的完成了無侵入式的組件應用

code spliting

可能上面的例子有點小打小鬧的感覺,那么我們換一個案例,再來體驗一下這種靜態替換式的注入的威力,我們采用官方支持較差的react作為參考(vue在code spliting方面做得真心是超級棒~)

import SingleImage from '../../component-modules/magic-single-image/src/index';import DoubleImage from '../../component-modules/magic-double-image/src/index';import ThreeImage from '../../component-modules/magic-three-image/src/index';// many component hereswitch (componentName) {case 'SingleImage':PreviewingComponent = SingleImage;break;case 'DoubleImage':PreviewingComponent = DoubleImage;break;case 'ThreeImage':PreviewingComponent = ThreeImage;break;// many component here}return(<PreviewingComponent></PreviewingComponent>)

一段中規中矩的代碼,對吧?相信大家已經發現了,在上述的代碼里面似乎并不是每個組件都是必須的,那么,基于以上的思考,可以對上面組件進行按需加載處理。 Bundle.jsx

import React, { Component, PropTypes } from 'react';class Bundle extends Component {static propTypes = {load: PropTypes.func,children: PropTypes.func,}state = {mod: null,}componentWillMount() {this.load(this.props);}componentWillReceiveProps(nextProps) {if (nextProps.load !== this.props.load) {this.load(nextProps);}}load(props) {this.setState({mod: null,});props.load().then((mod) => {this.setState({// handle both es imports and cjsmod: mod.default ? mod.default : mod,});});}render() {return this.state.mod ? this.props.children(this.state.mod) : null;}}export default Bundle;

以及相應的alias hook

export default (<Bundleload={() => import(/* webpackChunkName: "widget" */`../../component-modules/magic-single-image/src/index`)}>{Widget => <Widget {...props} />}</Bundle>)

思考,當組件多的時候每一個模塊都需要一個人口點嗎,可以從webpack.context角度簡化這個問題嗎?

以上兩個例子均是模塊引用作為join point來進行注入操作的,而且完成了無侵入式的功能增強,這得益于webpack將js模塊作為一等公民。我們擁有著超多的權利完成靜態式的注入工作。 本文并沒有在技術上涉及太多,還是那句話,拋磚引玉哈~~~

以上這篇淺談webpack下的AOP式無侵入注入就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 夹江县| 汤阴县| 将乐县| 咸丰县| 正镶白旗| 汉沽区| 宁都县| 四会市| 郸城县| 朝阳区| 本溪市| 斗六市| 西盟| 科技| 色达县| 锦州市| 长兴县| 广州市| 兴国县| 安远县| 永丰县| 桃源县| 莱阳市| 苏州市| 梅州市| 绥化市| 象山县| 慈溪市| 凤山市| 镇康县| 鄢陵县| 虎林市| 库车县| 新丰县| 西和县| 汪清县| 临武县| 都江堰市| 抚顺县| 铜山县| 夏邑县|