laravel-mix — 在后端项目中的构建方式

栏目: PHP · 发布时间: 6年前

内容简介:在前端构建工具兴起的同时,一大堆基于构建的UI和应用框架也随之吸引了了广大开发者的目光。从零上手构建工具 webpack 是每个前端开发者的噩梦,其余框架的构建配置也不能涵盖全部开发需求。对于传统后台管理应用,laravel 等主流框架仍提供页面渲染功能,但官方也提供了使用前端框架的一种加载方式。官方通过改进 webpack 构建工具,支持 vue 框架,sass 样式构建,使得前端工程化在整个项目中变得简单。

在前端构建 工具 兴起的同时,一大堆基于构建的UI和应用框架也随之吸引了了广大开发者的目光。

从零上手构建工具 webpack 是每个前端开发者的噩梦,其余框架的构建配置也不能涵盖全部开发需求。

对于传统后台管理应用,laravel 等主流框架仍提供页面渲染功能,但官方也提供了使用前端框架的一种加载方式。官方通过改进 webpack 构建工具,支持 vue 框架,sass 样式构建,使得前端工程化在整个项目中变得简单。

创建前端应用时,有以下几点需求

  • 支持较新语法的 JS 代码
  • 支持打包样式
  • 支持现代应用框架及基于框架的 UI 组件
  • 拥有依赖后端或者静态的部署方案

laravel-mix — 在后端项目中的构建方式

当我们使用 laravel 框架开发时,laravel-mix 已被包含在项目里,安装好 NodeYarn 解决依赖后开箱即用。

├── app
├── artisan
├── bootstrap
├── config
├── database
├── package.json  <----- project desc file of npm
├── phpunit.xml
├── public        <----- build file will in the public
├── resources     <----- frontend source code in this 
├── routes
├── server.php
├── storage
├── tests
├── vendor
└── webpack.mix.js <----- laravel-mix config file

laravel-mix — 在后端项目中的构建方式

通过包裹 webpack 实现了大部分功能,以便满足前端在项目中的工程化需求。

package.json 中有默认的一些开发和部署构建命令,使用 cross-env 来设置垮平台的环境变量。

"scripts": {
    "scripts": {
        "dev": "npm run development",
        "development": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js",
        "watch": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --watch --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js",
        "watch-poll": "npm run watch -- --watch-poll",
        "hot": "cross-env NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --config=node_modules/laravel-mix/setup/webpack.config.js",
        "prod": "npm run production",
        "production": "cross-env NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js"
    },
  },

webpack.mix.js

使用 webpack 的构建功能 ,先通过配置 webpack.mix.js 。在这里可以针对开发、生产环境做配置,甚至从底层重新配置 webpack 。

//webpack.mix.js
const { mix } = require('laravel-mix');

mix.setPublicPath('public')
    .js('resources/assets/js/app.js', 'js/').sourceMaps()
   .sass('resources/assets/sass/app.scss', 'css/')

默认情况下使用项目自带的命令 yarn run watch-poll 产出

dist
│  mix-manifest.json
│  
├─css
│      app.css
│      
└─js
        app.js

产出 mix-manifest.json 的作用是,结合模板渲染的方式,有组织地加载构建后的文件。

mix() 函数读取产出 mix-manifest.json 文件,替换对用路径为实际路径。但在生产模式下,为解决资源缓存问题,情况会更复杂。

{
    "/js/app.js": "/js/app.js",
    "/css/app.css": "/css/app.css"
}
<!-- welcome.blade.php -->
<link rel="stylesheet" href="{{ mix('css/app.css') }}"> 

<script src="{{ mix('js/app.js') }}"></script>

近年由于前端技术变化较快,其大呼的“前后端分离”,运用框架独有的构建方式,使得前端代码独立于后端渲染。这是一件好事情,但构建后的静态项目,部署往往更多时间去解决 “跨域” “文件缓存”等问题。

现在,部署依然可附属在整个后端项目中,作为现有模式的一个过渡,不必花太多时间在构建和分离部署上。

laravel-mix — 在后端项目中的构建方式


以上所述就是小编给大家介绍的《laravel-mix — 在后端项目中的构建方式》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Orange'S:一个操作系统的实现

Orange'S:一个操作系统的实现

于渊 / 电子工业出版社 / 2009-6 / 69.00元

《Orange S:一个操作系统的实现》从只有二十行的引导扇区代码出发,一步一步地向读者呈现一个操作系统框架的完成过程。书中不仅关注代码本身,同时关注完成这些代码的思路和过程。本书不同于其他的理论型书籍,而是提供给读者一个动手实践的路线图。读者可以根据路线图逐步完成各部分的功能,从而避免了一开始就面对整个操作系统数万行代码时的迷茫和挫败感。书中讲解了大量在开发操作系统中需注意的细节问题,这些细节不......一起来看看 《Orange'S:一个操作系统的实现》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具