亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

在 Laravel 項目中使用 webpack-encore的方法

2024-05-05 00:10:30
字體:
來源:轉載
供稿:網友

看過我之前寫過的博客的應該知道我一直是 laravel-mix 的死忠粉,有好幾篇文章都是關于它的。每每提到 laravel-mix 時更是不吝溢美之詞。然而就在大概一個月前,我卻決定不再使用它,而轉投 webpack-encore 陣營。

至于為什么放棄 laravel-mix,主要是因為它的維護狀況堪憂,不僅更新節奏緩慢,許多 Issue 久懸未決,更重要的是,作者似乎將很多 bug 完全寄希望于 webpack5,哪怕有熱心人士 PR 了,也通常被關掉,然后回復說“兄 dei,這個坑等 webpack5 出來就好了,我之前試過沒弄好,估計你這也填好坑,干脆安分點兒等 webpack5 吧”(不是原話,但差不多是這意思)。但最終讓我下定決心尋求替代方案的,則是這個 Issue ,細翻源碼,發現相關功能依賴的還是 extract-text-webpack-plugin,而這個包,早在 webpack4 發布不久就被宣布廢棄了(現在去看它的官方倉庫已經被設置為 archived),而作者似乎完全沒有使用 mini-css-extract-plugin 的意思。

正所謂愛之深,責之切,在對 laravel-mix 表示失望之后,我翻出了自己 star 多時的另一包 webpack-encore,雖說很早就 star 了,但之前卻沒試用過它,可能也是因為對于 laravel-mix 的偏愛,然而這次,不試便罷,試完之后大有相見恨晚之意。

webpack-encore 是 Symfony 官方的前端集成構建工具,同樣是基于 webpack,但它的 API 設計得更為友好,而且文檔更完善,當然更關鍵的一點是,坑更少啊……從開始讀它的文檔,倒把手里一個項目從 laravel-mix 遷移到 webpack-encore,只用了幾個小時,并且期間相當順利。而我遷移的這個項目,是一個 Laravel 項目,所以下面就分享下,如果在 Laravel 項目中使用 webpack-encore 替代 laravel-mix。

安裝依賴

首先當然是安裝依賴

yarn add -D @symfony/webpack-encore

需要注意的是,webpack-encore 沒有像 laravel-mix 那樣在自己內部依賴 vue-tempplate-compiler 之類的包,所以如果自己項目里用動了這些,需要自己在項目里手動安裝好。

配置 webpack

在項目根目錄下新建一個 webpack.config.js 文件并在其中配置 webpack-encore 功能(實際上它最終也是一個標準的 webpack 配置文件),以最基本的玩法為例。

const Encore = require('@symfony/webpack-encore')Encore// directory where compiled assets will be stored .setOutputPath('public/js/') // public path used by the web server to access the output path .setPublicPath('/js') // only needed for CDN's or sub-directory deploy //.setManifestKeyPrefix('build/') /*  * ENTRY CONFIG  *  * Add 1 entry for each "page" of your app  * (including one that's included on every page - e.g. "app")  *  * Each entry will result in one JavaScript file (e.g. app.js)  * and one CSS file (e.g. app.css) if you JavaScript imports CSS.  */.addEntry('app', './resources/js/app.js')// will require an extra script tag for runtime.js// but, you probably want this, unless you're building a single-page app .enableSingleRuntimeChunk() .cleanupOutputBeforeBuild().enableSourceMaps(!Encore.isProduction())// enables hashed filenames (e.g. app.abc123.css) .enableVersioning(Encore.isProduction()) .enableVueLoader() .enableSassLoader(options => {  options.implementation = require('sass') })// fetch the config, then modify it!const config = Encore.getWebpackConfig()// export the final configmodule.exports = config

新增 php helper 函數

Laravel 自帶了一個 mix() 函數用于引用 mix 編譯的資源,與之類似,syfony 也有這樣的函數,而且更為方便。為此你需要在 Laravel 項目中自行實現這兩方法,下面是我參考 symfony 里相關源碼改寫的,可能邏輯上并不算完善,但以自己一個多月的使用情況來看,它們表現良好。

use Illuminate/Support/HtmlString;/** * @param string $entryName * @return HtmlString */function encore_entry_link_tags(string $entryName): HtmlString{  $entryPointsFile = public_path('js/entrypoints.json');  $jsonResult = json_decode(file_get_contents($entryPointsFile), true);  if (!array_key_exists('css', $jsonResult['entrypoints'][$entryName])) {    return null;  }  $tags = array_map(function ($item) {    return '<link rel="stylesheet" href="'.$item.'" rel="external nofollow" />';  }, $jsonResult['entrypoints'][$entryName]['css']);  return new HtmlString(implode('', $tags));}/** * @param string $entryName * @return HtmlString */function encore_entry_script_tags(string $entryName): HtmlString{  $entryPointsFile = public_path('js/entrypoints.json');  $jsonResult = json_decode(file_get_contents($entryPointsFile), true);  if (!array_key_exists('js', $jsonResult['entrypoints'][$entryName])) {    return null;  }  $tags = array_map(function ($item) {    return '<script src="'.$item.'"></script>';  }, $jsonResult['entrypoints'][$entryName]['js']);  return new HtmlString(implode('', $tags));}

使用 encore_entry_link_tags 和 encore_entry_script_tags 引用編譯的前端資源

在模板里使用前面添加的 helper 函數引用資源,你會發現它比 Laravel 自帶的 mix() 函數更方便,只需要一個函數,就可以自動引入 vendor.js 和 app.js 了。

<!doctype html><html lang="{{ app()->getLocale() }}"><head>  <!-- Required meta tags -->  <meta charset="utf-8">  <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">  <!-- CSRF Token -->  <meta name="csrf-token" content="{{ csrf_token() }}">  <title>{{ config('app.name') }}</title>  <!-- app.css -->  {{ encore_entry_link_tags('app') }}</head><body>  <div id="app"></div>  {{ encore_entry_script_tags('app') }}</body></html>

修改 package.json 中的腳本(scripts)

因為 laravel 項目默認 package.json 中 develop 等相關的腳本都是使用 laravel-mix 的,為了方便日常開發,現在要對它們進行一些調整,改用 webpack-cocore。調整后大致如下,你也可以根據自己實際應用情況進行其它調整

"scripts": {  "dev": "npm run development",  "development": "cross-env NODE_ENV=development encore dev",  "watch": "npm run development -- --watch",  "watch-poll": "npm run watch -- --watch-poll",  "hot": "encore dev-server --port=9001 --hot",  "prod": "npm run production",  "production": "cross-env NODE_ENV=production encore production"},

運行腳本,愉快擼 BUG

做完前面的這些步驟之后,在終端執行 yarn run hot ,瀏覽器中輸入項目綁定的域名(如 app.test),就可以體驗方便高效的 HMR 開發了。

后記

使用 webpack-encore 已經快兩個月了,這期間總體說來相當順利,小坑雖然有,但沒什么大坑。去 github 上提 issue,維護成員基本上都很友善耐心,幾個小時就會有回復。這種態度也讓我對它更加放心了,相信它會折騰得越來越好。雖然 webpack-encore 是作為 Symfony 默認集成工具來設計的,但這并不妨礙它在 Laravel 中發揮強大威力。

相比于 laravel-mi,encore 的 API 以及一些默認配置方面考慮得更為科學和全面,想要配置 vue-loader 或者 ts-loader 之類的,只需要調用相應的方法。另外還有點讓我先驚訝的是,他們竟然對 watchOptions.ignored 的默認值也考慮到了,默認忽略 /node_modules/,降低 CPU 占用。當然,更為重要的是,mix4 里因為一些 bug 而無法使用的功能,在 encore 里卻正常,如 dynamic import。

總之,如果你已經發現了 laravel-mix 的種種不足但又苦于沒更好選擇的話,不妨試試 webpack-encore,相信你會對它愛不釋手。

總結

以上所述是小編給大家介紹的在 Laravel 項目中使用 webpack-encore的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧!


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产综合在线视频| 国产一区二区三区视频在线观看| 欧美午夜视频在线观看| 成人网在线视频| 久久久综合免费视频| 欧美亚洲午夜视频在线观看| 日韩精品一区二区三区第95| 欧美亚洲第一页| 国产在线观看91精品一区| 亚洲成人在线视频播放| 国产欧美日韩精品丝袜高跟鞋| 日韩欧美一区二区三区| 精品视频久久久久久| 日韩中文字幕在线视频播放| 亚洲色图国产精品| 国产精品国产三级国产专播精品人| 视频在线一区二区| 国产欧美日韩精品丝袜高跟鞋| 欧美成人久久久| 欧美精品久久久久久久久| 成人免费淫片视频软件| 日韩美女福利视频| 久久中文字幕一区| 欧美性猛交xxxx富婆弯腰| 色妞欧美日韩在线| 欧美日韩国产在线看| 久久精品视频网站| 国产精品女主播| 国产mv免费观看入口亚洲| 亚洲网站视频福利| 国产成人精品视频| 国产免费久久av| 日韩免费精品视频| 欧美日韩国产成人在线观看| 国产精品视频播放| 欧美亚洲午夜视频在线观看| 久99久在线视频| 国产亚洲精品美女久久久久| 久久久久久成人| 尤物99国产成人精品视频| 国产欧美一区二区三区在线看| 国产精品毛片a∨一区二区三区|国| 日韩欧美aaa| 成人中文字幕在线观看| 91精品久久久久久久久久入口| 精品五月天久久| 国产suv精品一区二区三区88区| 精品国模在线视频| 国产亚洲成精品久久| 亚洲精品国产综合区久久久久久久| 国产精品一区二区av影院萌芽| 成人羞羞国产免费| 欧美另类老女人| 久久九九免费视频| 亚洲国产中文字幕久久网| 欧美一区二区视频97| 亚洲精品一区av在线播放| 久久精品视频在线| 日韩美女在线观看| 欧美贵妇videos办公室| 正在播放欧美一区| 久久精品男人天堂| 欧美高清第一页| 亚洲风情亚aⅴ在线发布| 亚洲一区美女视频在线观看免费| 97香蕉超级碰碰久久免费的优势| 91精品国产91久久久久久吃药| 亚洲自拍偷拍第一页| 日本精品va在线观看| 亚洲精品国产精品国产自| 国产精品久久久久久久av电影| 中国日韩欧美久久久久久久久| 亚洲国产成人久久综合一区| 乱亲女秽乱长久久久| 欧美巨猛xxxx猛交黑人97人| 国产91久久婷婷一区二区| 国内精品国产三级国产在线专| 91高潮精品免费porn| 亚洲激情自拍图| 一区二区三区高清国产| 91久久国产婷婷一区二区| 国产成人中文字幕| 久热99视频在线观看| 久久夜色精品国产亚洲aⅴ| 亚洲成人网久久久| 国产丝袜一区二区三区| 伊人成人开心激情综合网| 91亚洲国产成人久久精品网站| 国产乱人伦真实精品视频| 日韩欧美精品免费在线| 欧美精品电影在线| 九九视频这里只有精品| 最新的欧美黄色| 亚洲精品videossex少妇| 成人网在线免费观看| 欧美一级视频免费在线观看| 91九色国产视频| 成人欧美一区二区三区在线| 亚洲欧美日韩成人| 久久久精品国产| 欧美日韩中文字幕日韩欧美| 欧美性色19p| 亚洲乱码国产乱码精品精| 日韩av大片在线| 国产中文字幕91| 久久亚洲欧美日韩精品专区| 97在线视频一区| 欧美午夜xxx| 91成人天堂久久成人| 久久亚洲电影天堂| 色偷偷综合社区| 亚洲精品91美女久久久久久久| 亚洲第一中文字幕| 国产综合久久久久| 欧美视频第一页| 午夜精品一区二区三区在线视| 精品国产欧美一区二区五十路| 日韩av影视在线| 日韩大陆毛片av| 日韩最新在线视频| 中文字幕在线日韩| 亚洲第一区第二区| 欧美精品久久久久a| 亚洲欧美日韩网| 97久久精品国产| 97久久精品视频| 国产精品18久久久久久麻辣| 97人洗澡人人免费公开视频碰碰碰| 午夜精品一区二区三区在线| 国产精品黄页免费高清在线观看| 欧美丝袜美女中出在线| 日韩精品中文字幕久久臀| 人九九综合九九宗合| 国产又爽又黄的激情精品视频| 97国产精品视频人人做人人爱| 国内精品一区二区三区| 亚洲视屏在线播放| 欧美日韩亚洲精品内裤| 黄色成人av网| 亚洲女人天堂成人av在线| 亚洲第一色中文字幕| 精品久久久久久中文字幕一区奶水| 激情av一区二区| 欧美在线视频播放| 91精品久久久久久久久| 国产精品久久久久久久久借妻| 欧美国产日韩xxxxx| 岛国av一区二区在线在线观看| 日韩国产精品视频| 日韩av中文字幕在线| 久久中国妇女中文字幕| 日韩精品在线免费播放| 欧美激情一区二区三区成人| 精品久久香蕉国产线看观看亚洲| 97香蕉超级碰碰久久免费软件| 日韩中文理论片| 国产a级全部精品| 国产做受69高潮| 欧美日韩国产123| 欧美视频二区36p| 亚洲精品wwww| 精品视频在线观看日韩| 日韩成人在线观看| 亚洲在线www|