在开发牛标联盟(www.niusb.com) 的时候,一直从事游戏服务后台开发,已经很长时间没有做过网站了,对从0开始写css也没有多大精力,只好选择现在流行的bootstrap来搭建前端的 基础框架。Bootstrap是一个优秀的框架,让我省去更多事,不过使得Bootstrap有得有失,你将不能直接支持低端的浏览器,比如IE6这类前 进的绊脚石,特别是Bootstrap3只支持IE8及以上,而且对IE8也只是勉强的支持,因为你IE8没很多css3特性是不支持的,牛标联盟使用了 Bootstrap3在IE8下面边框都是没有圆角的,效果差很多,还有很多Html5的特性也不支持,实在是IE6未死,IE8又至,前端的童鞋们真是 “祸不单行”啊!
为省事,后面Bootstrap3我就直接简称为bs3了,在写bs3的时候有时需在定制一些css属性,这有很多种选择。
1、直接到官方定制后下载css。定制
2、熟悉css的可以直接自定义css覆盖(重写)bs3的css,前题是要熟悉
3、最爽的方式当然是直接下载bs3的Less源文件来定制。 (究竟 Less是什么大家可以直接Google或度娘)
我选择了第3种方式,接下来就说说我的前端工具,Nodejs+Grunt,因为使用Grunt需要安装Nodejs支持,所以得先安装Nodejs, 详细的安装可以查看官方的文档,这里不细述,接下来安装Grunt,
npm install -g grunt-cli
在Cmd 运行以上的命令,装grunt-ci全局安装,这样以后任何地方都可以直接使用grunt命令了。
在你要使用grunt的项目目录下新建一个package.json文件,这个文件的作用是配置项目信息及模块依赖,我的项目文件内容如下:
{ "name": "niusb", "description":"niusb", "version": "0.1.0", "devDependencies": { "grunt": "~0.4.1", "grunt-contrib-jshint": "~0.6.2", "grunt-contrib-uglify": "~0.2.2", "grunt-contrib-concat": "~0.3.0", "grunt-contrib-watch":"~0.5.1", "grunt-contrib-less": "~0.6.4", "grunt-contrib-clean": "~0.5.0", "grunt-contrib-copy": "~0.4.1", "grunt-recess": "~0.3.3" } }
要编译bt3的less文件,grunt-contrib-less模块是必不可少的。
接下来就是Grunt的配置文件Gruntfile.js了,在项目目录下新建这个js文件后,关于Gruntfile.js的配置网站这方面的教程相当之多,我在此仅列出我的配置内容供参考。
module.exports = function(grunt) { grunt.initConfig({ pkg : grunt.file.readJSON('package.json'), setting : { srcLess : 'src/main/less', srcJs : 'src/main/javascript', distCss : 'src/main/webapp/css', distJs : 'src/main/webapp/js', }, clean : { build : { src : [ "build" ] } }, concat : { bootstrap : { src : [ '<%=setting.srcJs%>/bootstrap/*.js' ], dest : 'build/bootstrap.js' } }, uglify : { main : { src : [ '<%=setting.srcJs%>/application.js' ], dest : '<%=setting.distJs%>/application.min.js' }, other : { files : { '<%=setting.distJs%>/jquery-1.10.2.min.js' : [ '<%=setting.srcJs%>/jquery-1.10.2.js' ], '<%=setting.distJs%>/bootstrap.min.js' : [ '<%=setting.srcJs%>/bootstrap.js' ], '<%=setting.distJs%>/html5shiv.min.js' : [ '<%=setting.srcJs%>/html5shiv.js' ], '<%=setting.distJs%>/respond.min.js' : [ '<%=setting.srcJs%>/respond.min.js' ], '<%=setting.distJs%>/jquery.ui.widget.min.js' : [ '<%=setting.srcJs%>/jquery.ui.widget.js' ], '<%=setting.distJs%>/bootbox.min.js' : [ '<%=setting.srcJs%>/bootbox.js' ], '<%=setting.distJs%>/bootstrap-modal.min.js' : [ '<%=setting.srcJs%>/bootstrap-modal.js' ], '<%=setting.distJs%>/bootstrap-modalmanager.min.js' : [ '<%=setting.srcJs%>/bootstrap-modalmanager.js' ], '<%=setting.distJs%>/jquery.fileupload.min.js' : [ '<%=setting.srcJs%>/jquery.fileupload.js' ], '<%=setting.distJs%>/jquery.iframe-transport.min.js' : [ '<%=setting.srcJs%>/jquery.iframe-transport.js' ], '<%=setting.distJs%>/jquery.jcrop.min.js' : [ '<%=setting.srcJs%>/jquery.jcrop.js' ], '<%=setting.distJs%>/twitter-bootstrap-hover-dropdown.min.js' : [ '<%=setting.srcJs%>/twitter-bootstrap-hover-dropdown.js' ], '<%=setting.distJs%>/jquery.lazyload.min.js' : [ '<%=setting.srcJs%>/jquery.lazyload.js' ], '<%=setting.distJs%>/moment.min.js' : [ '<%=setting.srcJs%>/moment.js' ], '<%=setting.distJs%>/bootstrap-datetimepicker.min.js' : [ '<%=setting.srcJs%>/bootstrap-datetimepicker/bootstrap-datetimepicker.js' ], '<%=setting.distJs%>/bootstrap-datetimepicker.zh-CN.min.js' : [ '<%=setting.srcJs%>/bootstrap-datetimepicker/bootstrap-datetimepicker.zh-CN.js' ] } } }, recess : { options : { compile : true }, mainCompile : { files : { 'build/bootstrap-datetimepicker.css' : [ '<%=setting.srcLess%>/bootstrap-datetimepicker.min.css' ], 'build/application.css' : [ '<%=setting.srcLess%>/application.less' ], 'build/admin.css' : [ '<%=setting.srcLess%>/admin.less' ], 'build/user.css' : [ '<%=setting.srcLess%>/user.less' ] } }, thirdCompile : { files : { 'build/bootstrap.css' : [ '<%=setting.srcLess%>/bootstrap/bootstrap.less' ] } }, mainMin : { options : { compress : true }, files : { '<%=setting.distCss%>/bootstrap-datetimepicker.min.css' : [ '<%=setting.srcLess%>/bootstrap-datetimepicker.min.css' ], '<%=setting.distCss%>/application.min.css' : [ '<%=setting.srcLess%>/application.less' ], '<%=setting.distCss%>/admin.min.css' : [ '<%=setting.srcLess%>/admin.less' ], '<%=setting.distCss%>/user.min.css' : [ '<%=setting.srcLess%>/user.less' ] } }, thirdMin : { options : { compress : true }, files : { '<%=setting.distCss%>/bootstrap.min.css' : [ '<%=setting.srcLess%>/bootstrap/bootstrap.less' ], '<%=setting.distCss%>/font-awesome.min.css' : [ '<%=setting.srcLess%>/font-awesome.css' ], '<%=setting.distCss%>/jquery.fileupload-ui.min.css' : [ '<%=setting.srcLess%>/jquery.fileupload-ui.css' ], '<%=setting.distCss%>/jquery.jcrop.min.css' : [ '<%=setting.srcLess%>/jquery.jcrop.css' ] } } }, watch : { mainRecess : { files : [ '<%=setting.srcLess%>/application.less', '<%=setting.srcLess%>/admin.less', '<%=setting.srcLess%>/user.less' ], tasks : [ 'dist-compile-main', 'dist-recess-main' ] }, thirdRecess : { files : [ '<%=setting.srcLess%>/application.less', '<%=setting.srcLess%>/bootstrap/*.less' ], tasks : [ 'dist-recess-third' ] }, mainJs : { files : [ '<%=setting.srcJs%>/application.js' ], tasks : [ 'dist-js-main' ] } }, }); grunt.loadNpmTasks('grunt-contrib-concat'); grunt.loadNpmTasks('grunt-contrib-uglify'); grunt.loadNpmTasks('grunt-recess'); grunt.loadNpmTasks('grunt-contrib-clean'); grunt.loadNpmTasks('grunt-contrib-watch'); grunt.loadNpmTasks('grunt-contrib-copy'); grunt.registerTask('dist-compile-main', [ 'recess:mainCompile' ]); grunt.registerTask('dist-compile-third', [ 'recess:thirdCompile' ]); grunt.registerTask('dist-recess-main', [ 'recess:mainMin' ]); grunt.registerTask('dist-recess-third', [ 'recess:thirdMin' ]); grunt.registerTask('dist-js-main', [ 'uglify:main' ]); grunt.registerTask('dist-js', [ 'uglify' ]); grunt.registerTask('dist-css', [ 'recess' ]); grunt.registerTask('default', [ 'clean', 'dist-js', 'dist-css' ]); };
其中的watch就是用来监控less或 js文件变化的,当你修改了less文件,Grunt 马上会编译成 css 文件这样马上就能看到效果。以下在cmd里运行,监控文件变化动态编译。
grunt watch:mainRecess
英文比较头痛的童鞋可以到http://www.bootcss.com/查看Bootstrap的中文文档。
不过最近又一发不可收拾的喜欢上 http://semantic-ui.com/ 对非专业的前端或程序员来说简直没抗拒力,也许下一项目我就会使用她了,但是要想支持低端浏览器的童鞋你还是不要看了,她不是你的菜。
相关推荐
《图片批量处理小助手SignPics.exe:轻松批量编辑与优化图像》 在日常工作中,我们经常需要处理大量的图片,比如调整尺寸、添加水印、转换格式等。手动操作不仅耗时,而且容易出错。这时,一款强大的图片批量处理...
c904417ef980d9da9eabe32d217623a2.part1
game_patch_1.30.21.13210.pak
Java多线程,线程安全(同步锁、异步锁)
图书管理系统前端静态资源
教育机构绩效管理与绩效考核制度
华为MA5626/MA562空库文件
可以通过这个简易的demo来,锻炼刚开始接触JAVA的朋友们。 首先需要有JAVA开发环境,安装了JDK。 此代码展示了如何设置游戏面板、加载图像资源、初始化游戏状态、处理键盘输入以改变方向、更新游戏状态、检测碰撞和苹果收集等基本功能1。请注意,为了运行这个程序,你需要准备相应的图片资源(dot.png, food.png, head.png),并将其放置在正确的路径下(这里假设是src/resources/目录)。如果你没有这些图片文件,可以使用任何你喜欢的图片代替,或者直接绘制矩形作为替代
"单相Boost PFC电路双闭环控制策略仿真研究:电感电流内环与输出电压双环控制的运行特性及功率因数校正效果展示",单相boost PFC电路仿真 功率因数校正 采用双闭环控制方式 电感电流内环+输出电压双环控制 电路运行特性良好,如效果图所示 ,核心关键词:单相boost PFC电路仿真; 功率因数校正; 双闭环控制方式; 电感电流内环; 输出电压双环控制; 电路运行特性。,"双闭环控制单相Boost PFC电路仿真:电感电流与输出电压协同优化"
改进A星算法:优化路径规划,剔除冗余节点,平滑转折点,对比优化前后结果,改进A星算法 剔除冗余节点,光滑转折点 对比优化前后路径。 ,核心关键词:改进A星算法; 剔除冗余节点; 光滑转折点; 对比优化前后路径。,"优化A星算法:剔除冗余节点,平滑转折点,对比优化路径效果"
项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载 技术组成 语言:java 开发环境:idea 数据库:MySql8.0 部署环境:Tomcat(建议用 7.x 或者 8.x 版本),maven 数据库工具:navicat
基于滑膜控制的无人车辆多车道变换轨迹跟踪与路径规划——MATLAB仿真实现,基于滑膜控制无人车辆轨迹跟踪控制 复现滑膜控制 多车道变,MATLAB仿真 路径规划 无人船无人机 SMC控制 Sliding mode controller for trajectory tracking ,基于滑膜控制的无人车辆轨迹跟踪; 复现滑膜控制; 多车道变换; MATLAB仿真; 无人船无人机路径规划; SMC控制; Sliding mode controller。,基于滑膜控制的无人车辆多车道轨迹跟踪控制及仿真研究
基于定子磁链定向矢量控制策略的双馈风力发电系统研究:直接转矩输入与双PWM变换器控制,双馈风力发电系统,双pwm变器控制系统,采用直接转矩输入代替风力发电机。 (1)转子侧采用基于定子磁链定向的矢量控制策略,对d轴进行定向,采用双闭环控制结构,外环为速度环,内环为电流控制环。 (2)网侧采用基于dq解耦直接功率控制,使转子侧以单位功率因数消耗能量,功率因数为1。 (3)右侧加了转子电流过流保护电路(crowbar),并设置了一些参数突变,以便研究了双馈风力发电机在外界干扰下各转矩、功率、电压等波形变化。 附带说明 ,双馈风力发电系统; 双PWM变换器控制; 矢量控制策略; 功率因数1; 转子电流过流保护; 波形变化。,双馈风力发电系统:双PWM变换器直接转矩控制技术研究
2025年小学《义务教育道德与法治课程标准(2022年版)》试卷附含答案.docx
2025年义务教育新课程标准生物(2022年版)必考试题含答案.docx
单相ANPC仿真-逆变器通用-matlab/SIMetrix
数字农场项目建设方案.pptx
python国产进口电影票房榜单数据可视化(可视化大屏)
1.项目简介 基于JavaEE超市管理系统-可用于毕设-课程设计-练手学习。本系统利用网络沟通、计算机信息存储管理,有着与传统的方式所无法替代的优点。比如计算检索速度特别快、可靠性特别高、存储容量特别大、保密性特别好、可保存时间特别长、成本特别低等。 2.项目技术栈 • 数据库:MySQL • 开发工具:IDEA • 数据连接池:Druid • Web容器:Apache Tomcat • 项目管理工具:Maven • 版本控制工具:Git • 后端技术:Servlet+JDBC+Web+JSP • 前端框架:LayUI、HTML、CSS、Jquery 3.项目运行部分截图 4.项目配套万字文档 1.项目简介 根据系统需求与系统功能的分析,可以把系统总体分为:学生信息管理、专业信息管理、课程信息管理、学院信息管理等几大功能模块。每个模块分别定义了多个功能。可用下图的总体功能模块图表示 2.项目技术栈 • 数据库:MySQL • 开发工具:IDEA或Eclipse • 数据连接池:Druid • Web容器:Apache Tomcat •
1、文件内容:acpid-sysvinit-2.0.19-9.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/acpid-sysvinit-2.0.19-9.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装