准备工作

在此之前要安装node  、 npm 。这里安装node 、 npm 就不介绍了,百度一大把。

安装所有的npm依赖包

  1. //进入项目的根目录
  2. npm install

安装完后会出现一个node_modules目录

使用gulp编译sass

npm安装gulp(如果没有翻墙呢,那么很多包安装安装不了得)

  1. //全局安装
  2. npm intall --global gulp
  3. // 项目中安装
  4. npm install --save-dev gulp

不过建议用淘宝镜像安装gulp,可以使用我们定制的 cnpm (gzip 压缩支持) 命令行工具代替默认的 npm:

  1. npm install -g cnpm --registry=https://registry.npm.taobao.org

用淘宝的cnpm安装gulp(用了这个感觉速度超快)

  1. cnpm install gulp

在此可以做一个示例,在 resource/assets/sass/app.scss 文件中去掉第一行的注释符,如下图:

在控制台进行编译,显示已编译成功:

打开public/css/文件, 可知有一个app.css文件,说明编译成功:

如果想编译多个sass文件时,可以在gulpfile.js文件中修改至如下代码:

  1. // 编译道不同的文件中
  2. elixir(function(mix) {
  3. mix.sass('app.scss','public/css/first.css')
  4. .sass('two.scss','public/css/two.css');
  5. });
  6.  
  7. // 编译到同一个文件中
  8. elixir(function(mix) {
  9. mix.sass(['app.scss','two.scss'],'public/css/first.css')
  10. });

结果如下图:

使用gulp编译less文件

less的编译跟scss的编译非常相同,只需要给scss改为less即可,

  1. elixir(function(mix) {
  2. mix.less('app.less','public/styles');
  3. // .sass('two.scss','public/css/two.css');
  4. });

需要注意的一点就是,在编译的是候会默认的去resource/less文件路径,因此在编译之前需要改文件名,新建也可。

如果想自己配置文件less或scss文件的 路径可以添加如下代码,编译时,就会到配置的文件中去找资源:

gulp结果:

从上图提示的错误就可以知道配置的文件路劲起作用了。

合并压缩静态文件

  1. //elixir.config.assetsPath = 'assets';
  2.  
  3. elixir(function(mix) {
  4. // mix.less('app.less','public/styles');
  5. // .sass('two.scss','public/css/two.css');
  6. mix.styles(['a.css','b.css']);
  7. mix.scripts('js.js');
  8. });

gulp 结果:

可知并未起到压缩结果,只是把几个文件合并为一个文件

如果要起到压缩得结果来提高加载速度:

  1. gulp --production

laravel 解决缓存问题

在开发中,当我们更新了某个文件时,而本地又有缓存,因此得不到最新的效果。那如和解决这一个问题呢?

第一种:

手动得在链接地址添加 version 参数。并设置值,这样浏览器就知道更新

第二种:

在gulpfile.js中添加 version()方法并传入文件的路径

  1. elixir(function(mix) {
  2. mix.styles(['a.css','b.css']).version('/css/all.css');
  3. });

gulp下,在public文件夹下多了个build文件,同时也产生了一个hash文件

打开文件可知,在模板中,hash问价才是我们要引入的文件,只需在加载文件时,利用  elixir 方法即可

在浏览器中我们也可以检测到,成功加载

因此,在每次版本更新时,我们只需 gulp 下 就可以得到最新版本

yarn的使用及其简介

百度yarn  pk npm ,总体来说,yarn 比npm 更优越,

并行安装

清晰的输出

安装的时候无法保证速度/一致性

安全问题,因为 npm 安装时允许运行代码

功能差异  , Yarn 与 npm 很类似,但通过引擎的对比就能察觉 Yarn 的不同

安装可以参考官网  yarn安装

同时记得 PHP>5.6.4

我要去升级服务器了 , 太low了。

laravel与front-end的更多相关文章

  1. Laravel与Repository Pattern(仓库模式)

    为什么要学习Repository Pattern(仓库模式) Repository 模式主要思想是建立一个数据操作代理层,把controller里的数据操作剥离出来,这样做有几个好处: 把数据处理逻辑 ...

  2. laravel中如何写验证码文件,并防止中文乱码.

    本例为生成中文验证码,专为laravel而生. //控制器: public function getVcode(Request $request){ $width=845; $height=125; ...

  3. laravel/laravel和laravel/framework有何区别?

    在安装laravel的时候,我们一般是download github上的laravel/laravel,随后执行composer install,在这个过程中,你会发现composer其中的一项工作是 ...

  4. Laravel学习笔记(一)

         根据国外的调查,Laravel是最流行的框架,最近公司需要PHP的开发人员,但是一直招不到人,只好亲自上阵研究一下.由于以前对PHP只是大致了解,这次学习开始的时候也挺挠头的,到今天稍微入了 ...

  5. laravel前后台路由分离

    在laravel中创建文件放置前台和后台控制器 找到app/providers/RouteServiceProvider.PHP文件 在内配置 例: <?php namespace App\Pr ...

  6. laravel常见异常解决

    requested URL not found http://stackoverflow.com/questions/21458080/the-requested-url-projectname-us ...

  7. 【nginx,apache】thinkphp ,laravel,yii2开发运行环境搭建

    缘由 经常会有人问xx框架怎么配置运行环境,这里我就给贴出吉祥三宝(Yii2,Laravel5,Thinkphp5 )的Nginx和Apache的配置,供大家参考 Nginx Yii2 server  ...

  8. php Laravel 框架之建立后台目录

    今天研究了在Laravel框架中的控制器中加入后台的目录.发现了一些小的规律,拿来和大家分享一下吧. 通常情况下,我们是直接在controllers目录中加入我们的控制器,然后再routes.php ...

  9. Linux laravel安装

    第一步:安装php套件 目前为止laravel是5.1版本,需要对php有要求,要php5.59以上 The Laravel framework has a few system requiremen ...

  10. Laravel 精选资源大全

    原文链接  必备品 文档:Documentation API:API Reference 视频:Laracasts 新闻:Laravel News 中文文档 Laravel学院– Laravel 5. ...

随机推荐

  1. CentOS系统内核、操作系统位数以及系统参数查看

    2016-07-29 一.系统内核的查看方法 1.uname -a 显示详细的内核信息 Linux localhost.localdomain 3.10.0-229.el7.x86_64 #1 SMP ...

  2. 剑指offer-第五章总结

    优化时间和空间效率的方法: 1,时间换空间. 2,动态规划. 3,找规律.

  3. CSS书写格式

    转自: https://segmentfault.com/a/1190000005046830 CSS书写格式 1.格式化代码 1.1文件 [建议]:CSS文件使用无BOM的UTF-8编码 1.2缩进 ...

  4. jenkins 重置密码

      说明 最近在折腾jenkins,配置用户权限时点错了,选择了安全矩阵后没有添加用户,就保存配置了,然后就报错了,提示没有Overall/Read权限.还有另外一个问题,用户的密码忘记了怎么办? 一 ...

  5. Linux 中断下半部

    为什么使用中断下半部? 中断执行的原则是要以最快的速度执行完,而且期间不能延时和休眠! 可是现实中,中断中可能没办法很快的处理完需要做的事,或者必须用到延时和休眠,因此引入了中断下半部. 中断中处理紧 ...

  6. java代码 求和1+1/2+1/3+1/4+1/5+1/6+.......+1/n 的值~~~~

    总结:很简单的练习: s=1+1/2+1/3+1/4+1/5+1/6+.......+1/n的值:注意这里的s是float型,绝对记住不能留整数型 即s+=1/i; package com.c2; i ...

  7. window.open()打开新窗口被拦截

    window.open( url )是常用的打开新页面的方法,一般都没有问题,但是如果在ajax回调方法里面使用就会被浏览器拦截,因为在浏览器安全机制中,页面弹窗必须是由用户触发的才是安全弹窗,比如说 ...

  8. ansible里的item和with_items

    ################################## 变量命名 变量名仅能由字母.数字和下划线组成且只能以字母开头. ################################# ...

  9. 浅层神经网络 反向传播推导:MSE softmax

    基础:逻辑回归 Logistic 回归模型的参数估计为什么不能采用最小二乘法? logistic回归模型的参数估计问题不能“方便地”定义“误差”或者“残差”. 对单个样本: 第i层的权重W[i]维度的 ...

  10. Maven Assembly打包提示[WARNING] transitive dependencies if any will not be available

    maven assembly打包出现错误 [WARNING] The POM for com.flink.xxr:0.0.1-SNAPSHOT is invalid, transitive depen ...