编写大型项目web页面 从写web登陆页面开始
web页面搭建需要准备什么工具
首先我们会和设计师沟通 我们需要一些检验设计的工具
ps 自动裁图 自动测量工具
(我这里安利一下一个工具 我用的cutterman)
sketch 可以使用阿里的工具 marketch
拿到界面不要急着做 看看有什么问题
有些我都会问
pc端
ie8问题 如果要兼容ie8 我要考虑成本
如果是webapp 一个人办 可能会出现时间的问题 这个不要惊讶 一个人做webapp会不停重构
mobile端
uc问题
除此之外最重要的 控制住ui节奏 和ui搞好关系 告诉他们自己大约什么进度 要学会交流 不要设计出来 自己安排不过来就傻眼了
和后端沟通
咋们这页面怎么和后端配合 ajax怎么测 会不会有mockdata
沟通 通常前端的位置是定位于前后端桥梁的 这个我会在后文多次强调 另外咱么这个文章是一系列的 每个ui的实现 我可能会解读一下w3c文档 可能就会占用一篇文章
构建和审查工具
gulp
jshint
等等
技术选型
sass
postcss
typescript 或者 es6
登陆页面简单吗
好像貌似很简单 不就是一个表单吗
表单简单吗 如果简单js会因此流行开来吗
表单当然不简单 验证怎么做
先做页面 好的 这里问题来了
公司有没有前端库呢 有的话还简单点 没有就只能自己搭了
首先确认一下 既然做指南 说下兼容目标 ie8 可以看 ie9 可以用
ie8 最后解决 ie8解决问题 至少该pc端项目得配两个人
如何给css加ie的hack
<!doctype html>
<!--[if IE 8 ]><html class="ie8" lang="zh-cn"><![endif]-->
<!--[if IE 9 ]><html class="ie9" lang="zh-cn"><![endif]-->
<!--[if (gt IE 9)|!(IE)]><!--><html class="" lang="zh-cn"><!--<![endif]-->
ie 的模式
<meta http-equiv="X-UA-Compatible" content="IE=EDGE" />
也许有的页面会移动端也用
<meta name="viewport"
content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
360的保护
<meta name="renderer" content="webkit">
听说标准很值钱 dom4 有classlist奥
<script src="/assets/static/js/dom4.min.js"></script>
开始写
不急 我们先规划下
首先node_modules已成为事实上前端包管理目录 所以我们要在里面建立一个ui库
我自己一直在稳定更新自己的ui库zhilizhili-ui
ui布局 一开始要确定的
color
font
--某个项目静态目录
-- framework
-- elements
-- my module
-- sass
_color.scss
_font.scss
__color.scss
$custom-color: (
"blue": (
"500": #0f8ffe,
"600": #0088ff
),
"red": (
"600": #f26c4f
),
"green": (
"600": #d6e9ba
),
"yellow": (
"600": #ecf82c
),
"purple": (
"600": #e22cf8
),
"grey": (
"400": #c2c2c2,
"500": #898989,
"600": #464646
)
) !global;
@function get-custom-color($name, $level: "600") {
@return map-deep-get($custom-color, $name, $level);
}
_font.scss
@import "../../../../../node_modules/sassstd/src/sassstd";
@import "../../../../../node_modules/sassyjson/stylesheets/SassyJSON";
@import "../../../../../node_modules/scss-zhilizhili-mei/stylesheets/mei";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/full-parent";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/size";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/bem";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/query-selector";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/common/sim-querySelector";
@mixin interface-font() {
.font {
@content;
}
}
@mixin use-font() {
$defaults: (
".font": (
)
);
@include interface-font() {
@include register-hook("font");
@content;
}
}
@mixin use-amazeui-font($sel: body) {
#{$sel} {
font-family: "Segoe UI", "Lucida Grande", Helvetica, Arial, "Microsoft YaHei", FreeSans, Arimo, "Droid Sans","wenquanyi micro hei","Hiragino Sans GB", "Hiragino Sans GB W3", Arial, sans-serif;
}
}
font.scss 使用的是自己整合的sassstd 这是自己搜集的sass库
提供一些string map list的高级方法 还有等等啦scss-zhilizhili-mei 提供了一些简单的设计想法
大家平时一定要遵循dry法则
大家编写样式时尽量使用sass或者postcss写法 不要直接写css 这样做目的 希望代码可读性增加 模块化 就算现在只有你一个人 如果团队来新人 或者你离职 代码交给别人维护 大家都是程序员 何苦为难自己人
_color.scss
$custom-color: (
"blue": (
"500": #0f8ffe,
"600": #0088ff
),
"red": (
"600": #f26c4f
),
"green": (
"600": #d6e9ba
),
"yellow": (
"600": #ecf82c
),
"purple": (
"600": #e22cf8
),
"grey": (
"400": #c2c2c2,
"500": #898989,
"600": #464646
)
) !global;
@function get-custom-color($name, $level: "600") {
@return map-deep-get($custom-color, $name, $level);
}
首先项目一开始会有一个color的基本表述文件 定义为sass的一个全局变量
但是一些活动页面会有一些特殊的颜色 怎么办呢
$custom-color: map-extend($custom-color, (
"pink": (
"600": #f54c72
),
"green": (
"600": #4bbf4a
),
"blue": (
"600": #5093e1
),
"purple": (
"600": #442488
),
"grey": (
"200": #fbfbfb,
"300": #EDEFF5,
"400": #EAECEC,
"500": #A4ADBF,
"600": #50535E
)
)) !global;
使用map-extend 就可以修改custom-color颜色 如果当前页面有特殊颜色需求 就这么解决
一个标准的项目准备开始 我们需要什么呢 我们可以看张图
这是android material design的设计 下篇文章我们把前端样式这边梳理一下
编写页面代码
<div class="center-set">
<div class="center-set__item">
<form id="loginForm" action="" class="form login-form">
<div class="form__group">
<div id="email" class="form-field" data-regex="if: input, do: isEmail;"
v-on:regex-error="handleRegexError" v-on:regex-success="handleRegexSuccess" >
<input type="text" placeholder="Email">
</div>
<div class="tip">
<span class="icon"></span>
</div>
</div>
<div class="form__group">
<div id="password" class="form-field" data-regex="if: input, do: min(6) | max(15);"
v-on:regex-error="handleRegexError" v-on:regex-success="handleRegexSuccess">
<input type="password" placeholder="Password">
</div>
<div class="tip">
<span class="icon"></span>
</div>
</div>
<div class="form__group">
<button id="submit" type="submit" class="btn form__btn submit-btn">提交</button>
</div>
<div class="form__group">
<div class="center-set remeberme-set">
<div class="center-set__item">
<div class="form-checkbox">
<input type="checkbox">
<div></div>
</div>
</div>
<div class="center-set__item">
<span>keep me logged in</span>
</div>
</div>
</div>
</form>
</div>
</div>
没什么好说的 就是一些表单元素
编写js代码
在编写代码的之前 解决一些浏览器bug
ie9 input事件bug
// ie9 input 事件polyfill
(function (d) {
if (navigator.userAgent.indexOf('MSIE 9') === -1) return;
var elements = [], values = [], ev = d.createEvent('CustomEvent');
ev.initCustomEvent('input', true, true, {});
d.addEventListener('selectionchange', function() {
var actEl = d.activeElement;
if (actEl.tagName === 'TEXTAREA' || (actEl.tagName === 'INPUT')) {
var idx = elements.indexOf(actEl), el = elements[idx] || elements.push(actEl);
if (actEl.type === 'text' || actEl.type === 'password' || actEl.type === 'search') {
if (el.value !== values[idx]) {
values[idx] = el.value;
el.dispatchEvent(ev);
}
}
}
});
})(document);
对于登陆而言 js验证时一件很重要的事 通常需要解决 输入时检测 提示 提交时 监测 提示
这里我的想法是 提供一种通用写法 具体实现 可以不一样
<div id="email" class="form-field" data-regex="if: input, do: isEmail;"
v-on:regex-error="handleRegexError" v-on:regex-success="handleRegexSuccess" >
<input type="text" placeholder="Email">
</div>
假设整个项目有一个通用的validator的对象 这个实现不强求
我用的是validator.js if 后面是 触发事件名称 do 是验证方法
这种在html上写的语句 我叫做sml
// 解析sml
utils.sml = (function() {
function parse(str) {
var parseobj = {};
parseobj["event"] = str.match(/(?:if:)\s*\w*/g)[0].replace("if:", "").trim();
parseobj["regex"] = str.match(/(?:do:)[\s\w\(\),|]+/g)[0].replace("do:", "").split("|").map(function(item) {
var args = [];
var reg = /(?:\()[\w\s,]+/g;
if (item.indexOf("(") > -1 && item.indexOf(")") > -1) {
var val = item.match(reg)[0].replace("(", "").split(",");
args = args.concat(val);
}
return {
name: item.trim().replace(reg, "").replace(")", ""),
args: args
};
});
return parseobj;
}
return {
parse: parse
}
})();
data-regex="if: input, do: min(6) | max(15);"
如果有多个验证 就是用分隔符隔开 多个验证第一次错误时就退出
任何验证都要提供 regex-error 和 regex-success 两个方法
再说组件 每个html 组件 目前我是用vue实现的 但是我决定用angular2做了 所以不怎么说了
框架的validtor 需要保留每个待验证的方式 以便使用submit提交时可以验证 以便实现组件于页面逻辑的结构
form 组件我会写几篇文章
编写大型项目web页面 从写web登陆页面开始的更多相关文章
- 使用Vue写一个登陆页面并在管理页面查看和修改
注册页面代码如下html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...
- .Net程序猿玩转Android开发---(3)登陆页面布局
这一节我们来看看登陆页面如何布局.对于刚接触到Android开发的童鞋来说.Android的布局感觉比較棘手.须要结合各种属性进行设置,接下来我们由点入面来 了解安卓中页面如何布局,登陆页面非常eas ...
- Java Web(十四) 编写MyBookStore项目的总结
这几天一直没有发博文,原因是在写一个书城的小项目,作为web学习的最后沉淀,接下来就要到框架的学习了. --WH 一.项目介绍 从网上找的一个培训机构的小项目,名称叫做 书城购物网站 吧,其中就是分前 ...
- 分分钟教会你使用HTML写Web页面
在学习怎样使用HTML编写网页之前,我们必须先搞清楚什么是HTML?当然了不是系统的给大家介绍HTML的前世今生,假设对其身世感兴趣的小伙伴能够去问度娘,她会给你想要的答案. 所谓HTML,就是我们常 ...
- [置顶] 自己动手写Web容器之TomJetty之六:动态页面引入
传送门 ☞ 1.Web服务内功经脉 传送门 ☞ 2.让服务动起来 传送门 ☞ 3.掀起请求盖头来 传送门 ☞ 4.静态页面起步 传送门 ☞ 5.包装请求参数 在上一节,我们已经完成了TomJetty服 ...
- 第三方页面嵌入到web项目的方案 之 使用iframe嵌入
有些项目中可能会遇到这样的需求, 需要在一个项目中嵌入其他的项目的页面或者功能.并且需要这两个页面之间能够进行交互. 本文主要介绍如何实现这种第三方应用的嵌入, 主要有以下几个方向: 1.iframe ...
- JAVA WEB快速入门之从编写一个JSP WEB网站了解JSP WEB网站的基本结构、调试、部署
接上篇<JAVA WEB快速入门之环境搭建>,在完成了环境搭建后(JDK.Tomcat.IDE),现在是万事具备,就差写代码了,今天就来从编写一个JSP WEB网站了解JSP WEB网站的 ...
- 一步一步实现web程序信息管理系统之二----后台框架实现跳转登陆页面
SpringBoot springboot的目的是为了简化spring应用的开发搭建以及开发过程.内部使用了特殊的处理,使得开发人员不需要进行额外繁锁的xml文件配置的编写,其内部包含很多模块的配置只 ...
- 第一次写Web API接口
API是什么?只知道是网络接口,具体怎么写?不会!如何调用?不会!那怎么办? 第一次的经历~~ 需求:为其他项目提供一个接口 功能:为项目提供询盘信息和商家信息,格式为Json字符串 拿过来,就开始做 ...
随机推荐
- 洛谷 简单字符串 'P1055ISBN号码' 问题
题目描述如下: 知识点①:char数组与int型数字进行运算时,需要将 char[i]-'0' .比如 char c[5]; int i; for(i=0;i<5;i++) scanf(&quo ...
- appium ios 相对坐标点击和控件滑动操作
环境: 系统:ios 10.13.6 (17G12034) appium:1.14.0 xcode:10.1 iphone:iphone7 12.4 在尝试使用driver.tap([(a,b)],5 ...
- JZ-054-字符流中第一个不重复的字符
字符流中第一个不重复的字符 题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g&q ...
- Spring Cloud Alibaba 2021.0.1.0 发布:版本号再也不迷糊了
大家好,DD又来了! 3月9日,Spring官方博客发文:Spring Cloud Alibaba 2021.0.1.0发布了. 前段时间DD还在微信群里看到小伙伴吐槽Spring Cloud Ali ...
- 分布式边缘容器项目 SuperEdge v0.7.0 版本来袭!
作者 SuperEdge 开发者团队,腾讯云容器中心TKE Edge团队 摘要 SuperEdge是基于原生Kubernetes的分布式边缘云容器管理系统,由腾讯云牵头,联合英特尔.VMware威睿. ...
- 【面经】Java面试突击
基础语法 基本数据结构 Java 的基本数据类型有 8 种,包括 6 种数字类型.1 种字符类型和 1 种布尔类型. 基本数据类型总览 数字类型包括 4 种整数类型和 2 种浮点数类型,4 种整数类型 ...
- Centos8 下部署 ASP.net Core 程序
1.安装需要的SDK包,如果程序包含3.1版本,需要安装3.1的SDK. sudo dnf install dotnet-sdk-5.0dotnet --versiondotnet --list-ru ...
- 《手把手教你》系列基础篇(七十七)-java+ selenium自动化测试-框架设计基础-TestNG依赖测试- 上篇(详解教程)
1.简介 今天主要是讲解和分享:TestNG中一个类中有多个测试方法的时候,多个测试方法的执行顺序或者依赖关系的问题.如果不用dependsOnMethods,testNG会自动根据@Test方法名称 ...
- 从MyIE2平滑升级到Maxthon的完美方案
经过几个Beta版本的测试MyIE2改名为Maxthon的新版浏览器终于发布了正式版本.喜欢MyIE2的朋友们也可以放心的将你的MyIE2升级为Maxthon了.以下是MyIE2平滑过渡到Mathxo ...
- VS code 设置中文语言环境(实现语言切换自由)
1.打开vs code,然后按快捷键ctrl+shift+p,输入configure language>回车 2.选择Install Additional Languages... 3.在左侧选 ...