angular - webpack2 例子

来源:http://www.cnblogs.com/wbg21521/archive/2017/05/22/6889585.html
-Advertisement-
Play Games

用一周多的時間做了一個簡易的wap站 之前研究過webpack但是一直沒用過,這次公司要做一個h5網站,正好拿來練練手,話說angular1x對移動端不是很友好,但主要是angular1x比較熟悉,上手快,開發也快,就沒去考慮其他前端mvc框架。 好了webpack出了中文版以後,對於我們這些英語不 ...


用一周多的時間做了一個簡易的wap站

之前研究過webpack但是一直沒用過,這次公司要做一個h5網站,正好拿來練練手,話說angular1x對移動端不是很友好,但主要是angular1x比較熟悉,上手快,開發也快,就沒去考慮其他前端mvc框架。

好了webpack出了中文版以後,對於我們這些英語不是很好的來說真的是太棒了,話說angularjs啥時候也出個中文文檔就更好了,webpack官網:https://doc.webpack-china.org/
右上角可以選擇語言。

開始之前先看一下目錄文件:

項目文件目錄.png

第一步:
首先要使用webpack需要先安裝webpack,官網給出了好幾中安裝方式,就不多說了:

npm install --global webpack

因為我用的是webpack2 所以需要註意版本1x 到 2x 的配置差異,這裡官網也給出了詳細差異:https://doc.webpack-china.org/guides/migrating/

第二步webapck配置webpack.config.js:

const webpack = require('webpack'); //to access built-in plugins
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');

const config = {
   entry: './app/app.js',
   output: {
   path: path.resolve(__dirname, 'dist'),
   filename: 'bundle-[chunkhash].js',
   publicPath: "/mobile/dist/"
 },
 module: {
   rules: [
    {
       test: /\.(js|jsx)$/, 
       use: 'babel-loader'
    },
  
   {
      test: /\.css$/,
      use: ['style-loader','css-loader']
   },

  {
    test: /\.(png|jpg|jpeg|gif|woff)$/, 
    use: 'url-loader?limit=4192&name=[name].[ext]' 
  },

 ]
},
 plugins:[
    new HtmlWebpackPlugin({               //自動生成Html
        template:'./app/view/index.html',
        filename:'../app/index.html',
        inject:'body'
    })
]
};

module.exports = config;

這裡需要說的是
entry: './app/app.js' 是入口文件,所有的 js代碼都通過入口文件載入,我這裡就只用了 app.js ,但是也可以設置多個入口文件。

output: 設置輸出的路徑和文件,這裡我是將所有的 js 壓縮到了bundle.js中,這裡也是可以設置壓縮到多個文件的,文件後面我設置了 hash 值主要考慮瀏覽器緩存問題,module: 就是配置js css html 打包壓縮的規則,這裡寫法和 webpack1x 有較大差異,還需註意。

plugins: 插件,webpack 有很多內置插件,HtmlWebpackPlugin  是動態生成html的一個內置插件,主要的作用是可以動態的把壓縮後帶有 hash 值的js動態插入到 html 中。

配置就暫時說到這裡,然後再看看我們的入口文件,app.js,

var angular = require('angular');// 引入angular

var urlRouterProvider = require('angular-ui-router');

var uiLoad =  require('angular-ui-load');

var $jq = require('jquery');

var animate = require('angular-animate');

var ngModule = angular.module('app',['ui.router','ui.load','ngAnimate']); // 創建app

require('./factory.js')(ngModule,$jq);// 公共方法封裝

require('./route.js')(ngModule);// 引入路由文件

require('./directives.js')(ngModule,$jq);// 組件

require('./controller.js')(ngModule);// 控制器

require('./css/style.css');// 引入樣式文件

這裡主要把js依賴文件引入,然後把angular的路由和邏輯處理的js引入,方便前端模塊化編程,註視比較清晰就不多說了。單獨的js模塊直接按照原來的寫就ok了 區別就是在最外層寫一個module.exports = function(ngModule){}

項目代碼:https://github.com/wangbaogui123/angular-webpack2.git
微博:王小傑wbg


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JavaWeb一--瀏覽器技術 一、HTTP協議 1.1 HTTP定義 HTTP(Hypertext Transport Protocol),超文本傳輸協議。 一種詳細規定了瀏覽器和web伺服器之間互相通信的規則,通過網際網路傳送萬維網文檔的數據傳送協議。 1.2 協議原理 1.3 請求格式 * 第一 ...
  • 項目的需要,要整一個視頻直播,但又不想在其他平臺那種直播室盜鏈展示,那我就直接用播放器來實現rtmp流媒體伺服器推流吧!沒廢話,走起 1.你要有一個媒體伺服器,暫時用【盤古雲】,這個還好,算是不錯的平臺了。註冊就能用,貌似免費的一樣,哈哈不管那麼多先搭建一個,看圖: 圖解:【1】菜單,進入創建一個媒 ...
  • 昨天,我接到的公司老司機的命令,要求我完成一個萬年曆,目的是想通過日曆來利用ajax顯示報名信息。平時不怎麼重視日曆的我遇到了很多麻煩,幸好在公司的一臺機器上找到了問題解決的思路。雖然不知道這位sir是誰,但是我還是要感謝他,他的思路讓我明白了什麼是閏年,什麼是小月大月,跳轉月份的規則...總之,如 ...
  • 左圖為本博客右側截取的GIF圖,右圖為代碼效果 HTML: css: JS: 此效果主要通過間隔取兩數之間的隨機數來改變標簽的樣式。 ...
  • 通常我們設置元素的寬和高樣式經常會出現一些問題,比如以下css的設置: 比如以下的代碼: 實際上我們期望的結果可能是這樣: 但是實際上是這樣的: 因為我們實際的寬度和高度是這樣計算出來的: width(寬) + padding(內邊距) + border(邊框) = 元素實際寬度 height(高) ...
  • 文檔對象模型(Document Object Model,DOM)是使用 W3C 定義的 API (Application Program Interface) 來操作 HTML 文檔 (此處不局限於 HTML,亦可操作 XHTML、XML 等),使用戶可以與進行頁面交互。 它使用對象的表示方式來表 ...
  • 在JavaScript中,回調函數具體的定義為:函數A作為參數(函數引用)傳遞到另一個函數B中,並且這個函數B執行函數A。我們就說函數A叫做回調函數。如果沒有名稱(函數表達式),就叫做匿名回調函數。 callback 不一定用於非同步,一般同步(阻塞)的場景下也經常用到回調,比如要求執行某些操作後執行 ...
  • 一、水平居中設置-行內元素 1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>定寬塊狀元素水平居中</title> 6 <style> 7 div{ 8 border:1px solid red; 9 marg ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...