基于ES6模块标准通过webpack打包HTM5项目
本篇主要演示通过webpack打包phaser项目,webpack安装方法在此处就不一一赘述了
经常用phaser来写html5游戏的朋友可能会发现,当游戏场景比较多时,如果都写在一个js文件中那么将来会很难维护,如果分成多个JS分别来管理不同的场景将会很方便
1. 首先来到项目根目录
在该目录中打开命令行,然后启动webpack
2、在app目录中建立一个文件夹,主要用来放置打包前的文件
从图中可以很看到,分成了专门用来引导,预加载,游戏菜单,游戏主逻辑,等js文件,由于用的是ES6的模块语法,ES6的module是动态引用的,即对外暴露的是该模块的引用, 可以新建一个public.js专门用来存放共享的变量
//public.js 用来存放phaser对象,然后其他js文件都import该文件就可以使用phaser对象了
export default {
game: null, }
// main.js 是模块的入口,这里把需要打包的js文件引入进来,从上面的public文件代码中可以看到export了一个对象,在这里把phaser对象传递给public中的game属性。 import vars from './public.js';
import Boot from './boot.js';
import Preloader from './preloader.js';
import Menu from './menu.js';
import Game from './game.js'; var gameScore = 0;
var h = $(window).height();
var game = vars.game = new Phaser.Game(640, h, Phaser.CANVAS, 'game');//就是这里啦,
game.state.add('Boot',Boot);
game.state.add('Preloader',Preloader); game.state.add('Menu',Menu); game.state.add('Game',Game);
game.state.start('Boot');
//boot.js 用来添加加载条图片和启动加载页面 import vars from './public.js'; export default {
preload:function(){
vars.game.load.image('preloaderBar','assets/loading-bar.png');
},
create:function(){
vars.game.state.start('Preloader');
}
}
//preloader.js
import vars from './public.js'; export default {
preload : function(){
var preloadSprite = vars.game.add.sprite(vars.game.world.width/4,vars.game.world.height / 2 ,'preloaderBar');
var preloadText = vars.game.add.text(vars.game.width/2,vars.game.height/2+60,'0%',{font:'40px Arial',align:"center",color:"#fff"})
console.log(preloadSprite);
vars.game.load.setPreloadSprite(preloadSprite);
// vars.game.load.audio('drivin-home', 'assets/world.wav');
// vars.game.load.audio('ho-ho-ho', 'assets/bonbon.wav');
// vars.game.load.audio('hop', 'assets/bomb.wav');
vars.game.load.image('platform', 'assets/1.png');
vars.game.load.spritesheet('santa-running', 'assets/runman.png', 493/5, 174,5);
vars.game.load.image('snow-bg', 'assets/beijing1.png');
vars.game.load.image('snow-bg-2', 'assets/yuanjing1.jpg');
vars.game.load.image('snowflake', 'assets/xiaoshixiaoguo.png');
vars.game.load.image('logo', 'assets/name.png');
vars.game.load.image('startbtn', 'assets/bangzhujiantou.png'); vars.game.load.onFileComplete.add(function(){
var progress = vars.game.load.progress;
preloadText.text = progress+'%';
});
vars.game.load.onLoadComplete.add(function(){//所有资源加载完成
preloadText.kill();
vars.game.state.start('Menu');
})
},
create:function(){ }
}
//main.js
import vars from './public.js'; export default {
create : function(){
vars.game.add.tileSprite(0,0,vars.game.width,vars.game.height,'snow-bg-2').autoScroll(-50,0);
vars.game.add.tileSprite(0, 0, vars.game.width, vars.game.height, 'snow-bg').autoScroll(-100,0);
vars.logo = vars.game.add.sprite(vars.game.width / 2 - 158, 20, 'logo');
vars.logo.alpha = 0;
vars.game.add.tween(vars.logo).to({
alpha:1
},1000,Phaser.Easing.Linear.None,true,0);
vars.startBtn = vars.game.add.button(vars.game.width/2-89,vars.game.height -120,'startbtn',function(){ vars.game.state.start('Game');});
vars.startBtn.alpha = 0;
vars.game.add.tween(vars.startBtn).to({
alpha:1
},1000,Phaser.Easing.Linear.None,true,1000); }
}
//game.js 游戏主逻辑
import vars from './public.js'; export default {
create : function(){
vars.gameScore = 0;
vars.currentFrame = 0;
vars.particleInterval = 2*60;
vars.gameSpeed = 580;
vars.isGameOver = false;
vars.game.physics.startSystem(Phaser.Physics.ARCADE);
vars.bg_heaven = vars.game.add.tileSprite(0, 0, vars.game.width,vars.game.height, 'snow-bg-2').autoScroll(-50,0);
vars.bg = vars.game.add.tileSprite(0, 0, vars.game.width, vars.game.height, 'snow-bg');
vars.bg.fixedToCamera = true;
vars.bg.autoScroll(-vars.gameSpeed / 6, 0);
vars.platforms = vars.game.add.group();
vars.platforms.enableBody = true;
vars.platforms.createMultiple(5,'platform',0,false);
vars.platforms.setAll('anchor.x',0.5)
vars.platforms.setAll('anchor.y',0.5)
var plat;
for (var i = 0; i < 5; i++) {
plat = vars.platforms.getFirstExists(false);
plat.reset(i * 192, vars.game.world.height - 44);
plat.width = 300*0.6;
plat.height = 88*0.6;
vars.game.physics.arcade.enable(plat);
plat.body.immovable = true;
plat.body.bounce.set(0);
}
vars.lastPlatform = plat;
vars.man = vars.game.add.sprite(100,vars.game.height - 200,'santa-running');
vars.man.animations.add('run');
vars.man.animations.play('run',15,true);
vars.man.width = (493/5)*0.5;
vars.man.height = 174*0.5;
vars.game.physics.arcade.enable(vars.man);
vars.man.body.gravity.y = 1500;
vars.man.body.collideWorldBounds = true;
vars.game.camera.follow(vars.man);
vars.cursors = vars.game.input.keyboard.createCursorKeys();
vars.spacebar = vars.game.input.keyboard.addKey(Phaser.Keyboard.SPACEBAR);
vars.score = vars.game.add.text(20,20,'',{
font: '24px Arial',
fill: 'white'
});
},
update:function(){
if (!vars.isGameOver) {
vars.gameScore += 0.5;
vars.gameSpeed += 0.03;
vars.score.text = 'Score:' + Math.floor(vars.gameScore);
vars.currentFrame++;
var moveAmount = vars.gameSpeed / 100;
vars.game.physics.arcade.collide(vars.man,vars.platforms);
if (vars.man.body.bottom >= vars.game.world.bounds.bottom) {
vars.isGameOver = true;
vars.endGame();
}
if (vars.cursors.up.isDown && vars.man.body.touching.down || vars.spacebar.isDown && vars.man.body.touching.down|| vars.game.input.mousePointer.isDown && vars.man.body.touching.down || vars.game.input.pointer1.isDown && vars.man.body.touching.down) {
vars.man.body.velocity.y = -500;
}
vars.platforms.children.forEach(function(platform){
platform.body.position.x -= moveAmount;
if (platform.body.right <= 0) {
platform.kill();
var plat = vars.platforms.getFirstExists(false);//获得第一个不存在的子元素,参数为true则为获得第一个存在的子元素
plat.reset(vars.lastPlatform.body.right + 192,vars.game.world.height - Math.floor(Math.random() * 50) -24);
plat.body.immovable = true;
vars.lastPlatform = plat;
}
});
}
}
}
最后可以就可以通过webpack开始打包了
基于ES6模块标准通过webpack打包HTM5项目的更多相关文章
- webpack打包vue项目之后生成的dist文件该怎么启动运行
亲测,webpack打包vue项目之后生成的dist文件可以部署到 express 服务器上运行. 我的vue项目结构如下: 1. 进入该vue项目目录,打开git bash,执行:npm run b ...
- 如何使用webpack打包前端项目
webpack概述 随着前端体积越来越大,功能越来越丰富,这时候就需要将前端工程化,而 webpack就是用于将前端各种文件打包起来. 一个简单的webpack应该包含以下几个概念 · 入口起点 · ...
- 《你不知道的JavaScript -- 上卷》笔记 --- 基于ES6新标准
1.let A:let关键字:将变量绑定到所在的任意作用域 function process(){ //do something } //在这个块中定义的内容完事就可以销毁 { let someRea ...
- Webpack入门——使用Webpack打包Angular项目的一个例子
2016.1.22,对大多数人来说,这是一个非常平常的日子,但这却是我决定在博客园写博客的日子.虽然注册博客园的博客已有4年8个月,却一直没有动手写过一篇博客,原因是觉得自己水平不行,写不出好东西,所 ...
- 16.如何做到webpack打包vue项目后,可以修改配置文件
问题描述: 前端需要修改restful API的url,但是打包之后,配置文件找不到了,如果在npm run build 生成dist后,这个配置也被写死了,传到运行的前端服务器上后,假设某次,api ...
- Docker + webpack 打包前端项目
码云代码地址: https://gitee.com/caonimashi/docker_deployment_front_end 构建基础镜像: 1.下载一个 Apline Linux 操作系统 ...
- webpack打包nodejs项目(前端代码)
PS.若本文没有帮到你可以看看我的进阶版点此前往 适用情况 首先说明,此情况不具备普遍性.若你的情况与笔者类似那么希望这篇文章能够帮到你. 我的项目情况是这样的:用node.js做后台,ejs做模板引 ...
- webpack打包vue项目,资源路径如何从绝对路径改为相对路径?css中的图片资源如何修改配置?
资源相对引用路径 问题描述 一般情况下,通过webpack+vuecli默认打包的css.js等资源,路径都是绝对的. 但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,因为把配置的static ...
- 如何做到在webpack打包vue项目后,在外部动态修改配置文件
在我们做完vue项目后,只需要执行 npm run dist 就可以轻松进行打包转测试,可是如果我们临时需要修改一些配置文件比如域名,这时候我们就有点懵逼了,那就修改了再重新打一次包? NO NO N ...
随机推荐
- cookie设置
问题: cookie设置好后,谷歌浏览器下-->只有本页面有值,但是在其它浏览器下正常. $.cookie("userName",$("#loginName&quo ...
- UVa 10684 - The jackpot
题目大意:给一个序列,求最大连续和. 用sum[i]表示前i个元素之和,那么以第i个元素结尾的最大连续和就是sum[i]-sum[j] (j<i)的最大值,也就是找前i-1个位置sum[]的最小 ...
- Javascript 浮点运算问题分析与解决
分析 JavaScript 只有一种数字类型 Number ,而且在Javascript中所有的数字都是以IEEE-754标准格式表示的. 浮点数的精度问题不是JavaScript特有的,因为有些小数 ...
- 创建iwatch 程序选项
include complication :包含自定义表盘事件 include glance scene:包含缩略图事件
- PHP正则表达式验证是否含有中文
判断是否 有中文. if (preg_match("/[\x7f-\xff]/", $string)) { echo "true"; }else{ echo & ...
- Linux系统迁移
文章来源http://blog.csdn.net/gt945/article/details/12253585 sudo rsync -aAXvP --exclude-from=exclude.txt ...
- CSS继承性和层叠性
一. 继承性 1. 含义:从自己开始直到所包裹的最小的元素,都可以继承一些特有的属性. 2. 作用范围: a. color.text-开头的.line-开头的.font-开头的,均可以继 ...
- MyBatis 模糊查询
<!--${}是不进行预编译的,会直接进行sql语句的拼接:{}中的内容必须通过Map或者查询对象中获得--><select id="selectPersonByName& ...
- 理解FMS中的实例
FMS服务器端安装后,唯一需要注意的是设置端口,默认的访问端口是1935和80,如果服务器上安装了IIS提供 WEB服务,那么需要将80修改为其他端口如8080,否则,IIS将会无法工作.如果愿意,也 ...
- mac命令行对复杂ipa包重新签名
最近在做ios的自动化平台,需要通过命令行安装卸载ipa包 好了问题来,别人上传的ipa包,很可能是开发签名了只能在特定手机上安装的测试ipa包,那我们如何将其安装在我们的自动化的iphone上呢? ...