成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > 在 Laravel 項(xiàng)目中使用 webpack-encore的方法

在 Laravel 項(xiàng)目中使用 webpack-encore的方法

熱門標(biāo)簽:高德地圖標(biāo)注家 江西手機(jī)自動(dòng)外呼防封系統(tǒng)是什么 廣州防封卡外呼系統(tǒng)多少錢一個(gè)月 仁和怎么申請(qǐng)400開頭的電話 外呼系統(tǒng)撥打暫時(shí)無(wú)法接通 廣東地市地圖標(biāo)注 長(zhǎng)春人工外呼系統(tǒng)服務(wù)商 怎么向銷售公司推銷外呼系統(tǒng) 哪里辦理400電話

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

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

正所謂愛(ài)之深,責(zé)之切,在對(duì) laravel-mix 表示失望之后,我翻出了自己 star 多時(shí)的另一包 webpack-encore,雖說(shuō)很早就 star 了,但之前卻沒(méi)試用過(guò)它,可能也是因?yàn)閷?duì)于 laravel-mix 的偏愛(ài),然而這次,不試便罷,試完之后大有相見(jiàn)恨晚之意。

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

安裝依賴

首先當(dāng)然是安裝依賴

yarn add -D @symfony/webpack-encore

需要注意的是,webpack-encore 沒(méi)有像 laravel-mix 那樣在自己內(nèi)部依賴 vue-tempplate-compiler 之類的包,所以如果自己項(xiàng)目里用動(dòng)了這些,需要自己在項(xiàng)目里手動(dòng)安裝好。

配置 webpack

在項(xiàng)目根目錄下新建一個(gè) webpack.config.js 文件并在其中配置 webpack-encore 功能(實(shí)際上它最終也是一個(gè)標(biāo)準(zhǔn)的 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 函數(shù)

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

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 函數(shù)引用資源,你會(huì)發(fā)現(xiàn)它比 Laravel 自帶的 mix() 函數(shù)更方便,只需要一個(gè)函數(shù),就可以自動(dòng)引入 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)

因?yàn)?laravel 項(xiàng)目默認(rèn) package.json 中 develop 等相關(guān)的腳本都是使用 laravel-mix 的,為了方便日常開發(fā),現(xiàn)在要對(duì)它們進(jìn)行一些調(diào)整,改用 webpack-cocore。調(diào)整后大致如下,你也可以根據(jù)自己實(shí)際應(yīng)用情況進(jìn)行其它調(diào)整

"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"
},

運(yùn)行腳本,愉快擼 BUG

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

后記

使用 webpack-encore 已經(jīng)快兩個(gè)月了,這期間總體說(shuō)來(lái)相當(dāng)順利,小坑雖然有,但沒(méi)什么大坑。去 github 上提 issue,維護(hù)成員基本上都很友善耐心,幾個(gè)小時(shí)就會(huì)有回復(fù)。這種態(tài)度也讓我對(duì)它更加放心了,相信它會(huì)折騰得越來(lái)越好。雖然 webpack-encore 是作為 Symfony 默認(rèn)集成工具來(lái)設(shè)計(jì)的,但這并不妨礙它在 Laravel 中發(fā)揮強(qiáng)大威力。

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

總之,如果你已經(jīng)發(fā)現(xiàn)了 laravel-mix 的種種不足但又苦于沒(méi)更好選擇的話,不妨試試 webpack-encore,相信你會(huì)對(duì)它愛(ài)不釋手。

總結(jié)

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

標(biāo)簽:文山 黔東 湘西 海北 梅河口 廈門 惠州 濮陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在 Laravel 項(xiàng)目中使用 webpack-encore的方法》,本文關(guān)鍵詞  在,Laravel,項(xiàng),目中,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在 Laravel 項(xiàng)目中使用 webpack-encore的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于在 Laravel 項(xiàng)目中使用 webpack-encore的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国内精品久久国产| 91女主播在线观看| 久草在.com| 久久免费一级片| 夜夜爽av福利精品导航| 一本色道久久88精品综合| 97国产在线视频| 一道精品一区二区三区| 国产l精品国产亚洲区久久| 99免费视频观看| 亚洲男人在线| 亚洲视频免费观看| 岛国av免费在线观看| 欧美久久久久久久久久久久久| 色综合久久六月婷婷中文字幕| 精品国产三级a在线观看| 亚洲aa在线| 欧美日韩精品免费观看| 一级做a爱视频| 亚洲大全视频| 亚洲天堂av网| 欧美一区二区三区久久综| 国产乱码精品一区二区三区精东| 青青在线视频免费观看| 激情成人综合| 国产一二三四视频| 激情小说欧美色图| 疯狂揉花蒂控制高潮h| 一区二区视频在线观看免费的| 国产区亚洲区欧美区| 国精产品久拍自产在线网站| www.伊人久久| 婷婷久久综合九色国产成人| 久久一区二区免费播放| 91精品国产黑色紧身裤美女| 视频一区免费在线观看| 中文字幕在线免费| 羞羞视频在线免费看| 成人精品在线观看视频| www.超碰在线.com| 香蕉久久国产av一区二区| 波霸ol色综合网| 黄色片网站在线播放| 自拍偷拍在线视频| 精品久久久三级| 美女日批免费视频| 小草在线视频免费播放| 欧美在线二区| 米奇777四色精品人人爽| 久久综合国产精品台湾中文娱乐网| 最近中文字幕2019免费| 美女高潮网站| 久久久亚洲精选| 国产午夜一区| 美女视频黄 久久| 999在线精品| 有码av在线| 国产精品成av人在线视午夜片| 成人手机视频在线| 久久久久国产精品麻豆| 欧美婷婷六月丁香综合色| 日本特级黄色大片| 欧美日韩理论| 无人在线观看的免费高清视频| 欧美一区二区三区四区夜夜大片| 日本伊人精品一区二区三区介绍| 成人精品小视频| 大肉大捧一进一出好爽动态图| 国产成人精品视频| 在线视频不卡一区二区| 97视频在线观看网址| 日韩视频―中文字幕| 福利视频一区二区| 欧美日韩一区二区三区不卡视频| 国产精品欧美久久久久一区二区| 欧美最猛黑人xxxx黑人猛交3p| 韩国xxxx做受gayxxxx| 日韩精品一区二区三区久久| 久久精品福利| eeuss影院在线播放| 国产黄a三级三级三级| 亚洲精品第五页| 北条麻妃一二三区| 337p亚洲精品色噜噜狠狠| 久热视线观看免费视频| 欧美成人午夜影院| 亚洲裸色大胆大尺寸艺术写真| 婷婷在线视频| 国产女主播一区二区三区| 91超碰在线观看| 秋霞成人午夜伦在线观看| 国产福利在线免费| theav精尽人亡av| 欧美日一区二区三区在线观看国产免| 国产z一区二区三区| 成人av资源电影网站| 97超碰资源| 欧美日韩人人澡狠狠躁视频| 精品毛片免费观看| 老妇女50岁三级| 亚洲视频在线观看日本a| 国产精品一区亚洲| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲最新视频在线观看| 国产精品电影一区二区| 97热在线精品视频在线观看| 久久99国产精品久久99果冻传媒| 亚洲精品欧美二区三区中文字幕| 精品一区免费av| 动漫3d精品一区二区三区| 卡一精品卡二卡三网站乱码| 亚洲欧洲日韩综合| 欧美日韩精品高清| 国产亚洲精品久久飘花| 一区二区三区视频免费视频观看网站| 国产伦精品一区二区三区高清| 日本一本二本在线观看| 亚洲成人av片| 日本xxxwww免费视频| 精品视频在线免费观看| 狠久久av成人天堂| 国产成人av电影在线播放| 69堂国产成人免费视频| 99久久精品国产亚洲| 特大黑人巨人吊xxxx| 欧美在线三级电影| 偷拍中文亚洲欧美动漫| 亚洲欧美综合国产精品一区| 久久久精品2019中文字幕之3| 战狼4完整免费观看在线播放版| 日本免费一区二区六区| 激情综合婷婷| 亚欧美无遮挡hd高清在线视频| 久久久久免费看黄a片app| 在线观看国产精品91| 中文字幕人妻一区二区三区视频| 国产网红主播福利一区二区| 亚洲大片av| 欧美性大战久久久久xxx| 99久久婷婷国产综合精品首页| av在线亚洲男人的天堂| 日日干夜夜操s8| 亚洲乱码一区| 久久国产精品99精品国产| 日韩一区二区高清视频| 先锋影音国产精品| 北条麻妃高清一区| 日韩禁在线播放| 91精品久久久久久久| 国产精品视频在线免费观看| 红桃视频 国产| 日日摸夜夜爽人人添av| 日韩免费在线观看视频| 久操视频在线免费播放| 久久久久欧美精品| 综合久久婷婷| 欧美视频一二区| 九九热在线播放| 亚洲综合色噜噜狠狠| 国产寡妇亲子伦一区二区三区四区| 久久一二三四区| 国产欧美69| 成人看片在线| 国产在线黄色| 宅男噜噜噜66国产免费观看| 1069男同网址| 91精品人妻一区二区三区果冻| 重囗味另类老妇506070| 污黄视频在线看| www国产精品com| 卡一卡二卡三在线观看| 亚洲婷婷久久综合| 国产色婷婷国产综合在线理论片a| 99久久久久久| 林心如三级全黄裸体| 国产精品久久久影院| av之家在线观看| 中文在线官网天堂| 在线观看一区二区三区四区| 97人人模人人爽人人喊38tv| 2020国产精品久久精品美国| 欧美男人亚洲天堂| 亚洲天堂网一区| 91精品在线一区| 日韩精品免费一线在线观看| 在线香蕉视频| 精品无人乱码一区二区三区| 国产成人免费在线观看视频| 国产丝袜美腿一区二区三区| 国产精品白嫩初高中害羞小美女| 精品日韩电影| 国产香蕉在线观看| 欧美少妇在线观看| 尤物在线视频| 国产亚洲精品超碰| 日韩午夜在线影院| 亚洲va欧美va国产综合久久| 1024在线播放| 97超碰在线播放| 精品国产一区二区精华| 日韩一区二区免费在线电影| 国产一二三区在线| 日本黄视频网站| 超碰在线97免费| 免费在线观看黄| 精品国产免费观看一区| 91麻豆精品一二三区在线| 人与嘼交av免费| 久久免费视频6| 怡红院精品视频| 99影视tv| 中文字幕亚洲综合久久| 亚洲精品中文字幕乱码三区91| 久久久人成影片一区二区三区| 色偷偷在线观看| 色8久久久久| 国产高清视频免费在线观看| 色哟哟精品一区| 欧美成年人视频| 欧美色图片你懂的| 日韩乱码一区二区三区| 99九九99九九九99九他书对| 麻豆电影在线观看| www.狠狠| 美女视频网站黄色亚洲| 成人影片在线播放| 91小视频在线播放| 国产美女在线精品免费观看| 91av日本| 国产欧美日韩综合精品一区二区三区| 亚洲三级电影在线观看| 久久综合五月天| 尤物网站在线看| 香蕉视频在线播放| 国产国语性生话播放| 四虎成人免费在线| 999久久久精品一区二区| 亚洲电影欧美电影有声小说| 日本在线观看一区二区| 色一情一乱一伦一视频免费看| 精品国产污网站| 国产精品视频男人的天堂| 一区二区三区不卡视频在线观看| 亚洲国产片色| 欧美日本视频在线| 一区二区日韩av| 尤物视频网站| 中国特黄一级片| 99久久99久久| 国产精品极品美女粉嫩高清在线| 51久久夜色精品国产麻豆| av影片在线一区| 欧美黄网在线观看| 成人乱色短篇合集| 日韩影视在线| 国产免费高清| 999精品视频在线| 日韩欧美小视频| 国产成人亚洲欧洲在线| 真实国产乱子伦精品一区二区三区| 99精品在免费线偷拍| 欧美性高清videossexo| 国产精品日韩欧美综合| 亚洲一区999| 国产一区国产二区国产三区| 亚洲成人福利在线观看| 亚洲男人都懂第一日本| 日本福利专区在线观看| 欧美激情欧美狂野欧美精品| 亚洲AV无码久久精品国产一区| 国产情侣自拍小视频| 日韩视频 中文字幕| 国产主播喷水一区二区| 91一区二区三区在线| 国产后进白嫩翘臀在线观看视频| 欧美日本韩国在线| 日本少妇xxxx动漫| 日本wwwcom| 国产精选在线观看91| 日本一区二区在线不卡| 国产在线拍偷自揄拍精品| 亚洲成人自拍偷拍| 国产成人在线中文字幕| 欧美日韩精品在线观看视频| 2021av在线| 福利资源在线久| 国产视频1区| 日韩第二十一页| 日韩色图在线观看| 久久免费精品国产久精品久久久久| 欧美精品三级在线观看| 九九综合在线| 欧美一级二级三级| 一区二区三区国产免费| 亚洲尤物在线视频| av在线精品| 97色在线观看免费视频| 深夜福利一区二区| 日韩av一二三四| 97免费在线观看视频| 91精品无人成人www| 亚洲美女在线播放| 亚洲色成人www永久网站| 人操人爱免费视频| 男女免费视频网站| 国产美女精彩久久| 国产在线播放不卡| 香蕉成人啪国产精品视频综合网| 极品尤物一区二区三区| 欧美v亚洲v综合v国产v仙踪林| 精品国产青草久久久久福利| 国语对白一区二区| 欧美精品国产一区| 欧美私人情侣网站| 日本一区二区不卡视频| 欧美一级淫片丝袜脚交| 四虎影视在线播放| 国产精品福利影院| 久久久久久久久久一区二区三区| 婷婷久久五月天| 亚洲黄色www| 男人艹女人在线观看| 欧美中文字幕在线| 香蕉视频免费网站| 久久99久久久精品欧美| 欧美激情免费观看| 在线国产精品网| 男人扒开美女尿口无遮挡图片|