婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 在 Laravel 項目中使用 webpack-encore的方法

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

熱門標簽:高德地圖標注家 江西手機自動外呼防封系統是什么 廣州防封卡外呼系統多少錢一個月 仁和怎么申請400開頭的電話 外呼系統撥打暫時無法接通 廣東地市地圖標注 長春人工外呼系統服務商 怎么向銷售公司推銷外呼系統 哪里辦理400電話

看過我之前寫過的博客的應該知道我一直是 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 config
module.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的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧!

標簽:文山 黔東 湘西 海北 梅河口 廈門 惠州 濮陽

巨人網絡通訊聲明:本文標題《在 Laravel 項目中使用 webpack-encore的方法》,本文關鍵詞  在,Laravel,項,目中,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《在 Laravel 項目中使用 webpack-encore的方法》相關的同類信息!
  • 本頁收集關于在 Laravel 項目中使用 webpack-encore的方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91在线观看美女| 中文字幕在线观看一区二区| 国产不卡在线视频| 免费精品99久久国产综合精品| 久久久久久久久久久99999| 欧美一区二区在线播放| 91丝袜美腿高跟国产极品老师| 国产成人综合在线播放| 激情亚洲综合在线| 久久国产尿小便嘘嘘尿| 蜜乳av一区二区| 日本欧美加勒比视频| 亚洲国产精品久久人人爱蜜臀| 国产精品久久久久久久岛一牛影视| 欧美精品一区二区三区久久久| 久久久欧美精品sm网站| 欧美高清在线视频| 亚洲色欲色欲www| 五月婷婷久久丁香| 国产精品1区2区3区在线观看| 成人一区二区三区视频在线观看| 成人av小说网| 在线影视一区二区三区| 精品国产伦理网| 亚洲精品乱码久久久久久| 天天综合色天天综合色h| 国产精品自在在线| 在线成人av影院| 国产网红主播福利一区二区| 亚洲免费成人av| 国产精品99久久久久久久vr| 欧美视频中文一区二区三区在线观看 | 麻豆91精品91久久久的内涵| 国产精品一级在线| 欧美精选午夜久久久乱码6080| 精品成人一区二区三区四区| 午夜欧美一区二区三区在线播放| 波多野结衣中文字幕一区| 日韩视频一区二区三区在线播放| 1区2区3区欧美| 福利一区二区在线| 久久精品夜夜夜夜久久| 国产在线国偷精品免费看| 精品久久久久久无| 国产老肥熟一区二区三区| 欧美一区二区三区四区久久| 五月婷婷综合激情| 欧美精品丝袜久久久中文字幕| 亚洲精品写真福利| 欧美亚洲一区二区在线| 亚洲一区在线电影| 6080yy午夜一二三区久久| 日本美女一区二区| 日韩精品一区二区三区在线播放| 美国精品在线观看| 国产精品日韩成人| 色综合一区二区三区| 亚洲自拍另类综合| 欧美精品一区二区三区视频| 成人免费视频播放| 香蕉影视欧美成人| 欧美v日韩v国产v| 99re热这里只有精品视频| 亚洲国产视频直播| 国产嫩草影院久久久久| 色婷婷综合视频在线观看| 青椒成人免费视频| 亚洲国产成人一区二区三区| 在线不卡中文字幕| 色婷婷一区二区| 国产盗摄视频一区二区三区| 国产精品第五页| 91蝌蚪国产九色| 韩国女主播一区| 亚洲第一综合色| 国产精品乱人伦中文| 亚洲精品一线二线三线| 欧美丰满嫩嫩电影| 欧美日韩亚洲综合| 色哦色哦哦色天天综合| 成人91在线观看| 99精品视频免费在线观看| 美女mm1313爽爽久久久蜜臀| 亚洲激情图片qvod| 亚洲1区2区3区视频| 亚洲一区二区三区四区五区中文| 国产精品无遮挡| 亚洲女爱视频在线| 首页国产欧美日韩丝袜| 亚洲高清免费在线| 男女激情视频一区| 国产一区在线不卡| proumb性欧美在线观看| 99re在线视频这里只有精品| 色综合久久综合网97色综合| 欧美三级欧美一级| 精品国产一区二区亚洲人成毛片| 精品国产第一区二区三区观看体验 | 91精品久久久久久蜜臀| 亚洲激情第一区| 欧美a级一区二区| 蜜臀av一区二区三区| 国产精品伊人色| 99精品国产91久久久久久| 在线观看www91| 精品成人一区二区三区| 一区二区在线观看视频| 久久精品免费观看| 色88888久久久久久影院按摩 | 99精品国产热久久91蜜凸| 在线综合亚洲欧美在线视频| 一区在线观看视频| 免费av成人在线| 欧美日韩另类一区| 亚洲欧美日韩久久精品| 成人av资源在线观看| 国产午夜精品理论片a级大结局| 日韩精品亚洲专区| 99久久精品情趣| 国产欧美视频在线观看| 一区二区三区精品在线观看| 精品制服美女丁香| 在线观看亚洲专区| 中文字幕不卡在线观看| 亚洲高清一区二区三区| 欧美老肥妇做.爰bbww| 国产日本欧洲亚洲| 国产麻豆91精品| 国产午夜精品一区二区三区四区| 精东粉嫩av免费一区二区三区| 欧美一区二区三区播放老司机| 五月综合激情网| 国产日韩欧美高清| 色综合视频在线观看| 午夜视频久久久久久| 日韩亚洲欧美成人一区| 美女高潮久久久| 日韩欧美国产一二三区| 国产一区二区成人久久免费影院| 中文字幕不卡在线观看| 欧美日韩电影在线播放| 国产麻豆精品在线观看| 欧美四级电影在线观看| 国产精品久久久久久久蜜臀 | 亚洲美女在线国产| 亚洲精品美腿丝袜| 免费美女久久99| 久久久久亚洲蜜桃| 粗大黑人巨茎大战欧美成人| 亚洲人成电影网站色mp4| 欧美精品一区二区三区视频| 欧美日韩一区小说| 91黄色免费网站| 91片黄在线观看| 丁香五精品蜜臀久久久久99网站| 青青国产91久久久久久| 一区二区三区加勒比av| 亚洲免费在线电影| 18欧美亚洲精品| 最新国产の精品合集bt伙计| 日韩欧美视频一区| 久久蜜桃av一区精品变态类天堂| 99re免费视频精品全部| 丁香婷婷综合网| 国产白丝精品91爽爽久久| 国产精品456| 91免费精品国自产拍在线不卡| 国产精品一区三区| proumb性欧美在线观看| 不卡的av网站| 欧美日韩午夜影院| 日韩午夜激情av| 欧美mv和日韩mv国产网站| 日韩三级免费观看| 精品噜噜噜噜久久久久久久久试看| 欧美一区三区二区| 国产午夜精品一区二区三区视频| 亚洲国产高清在线| 日韩av不卡在线观看| 91视频国产观看| 日韩 欧美一区二区三区| 成人免费视频视频| 久久久国产综合精品女国产盗摄| 国产综合久久久久久久久久久久| 在线视频国内自拍亚洲视频| 最新久久zyz资源站| 捆绑紧缚一区二区三区视频| 欧美一区二区三区免费观看视频| 亚洲午夜激情av| 91精品国产欧美日韩| 精品一二三四区| 久久精品在线观看| 国产盗摄视频一区二区三区| 久久精品男人的天堂| 亚洲免费高清视频在线| 日本怡春院一区二区| 亚洲综合一区二区三区| 午夜精品福利一区二区蜜股av| 久久99蜜桃精品| 欧美日韩激情一区二区|