澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

web前端学习之前端重构方案,前端重构方案了解

2019-08-10 作者:澳门新萄京赌场网址   |   浏览(106)

前端重构方案了解一下

2018/06/09 · 基础技术 · 重构

原文出处: 吃葡萄不吐番茄皮   

前端技术发展很快,很多项目面临前端部分重构,很开心可以让我进行这次项目前端的重构方案编写,在思考的同时参考了网上很多资料,希望本篇重构方案有一定的完整性,可以带给大家一些在面临重构时有用的东西,同时希望路过的大牛小牛不领赐教,能给我略微指点下重构相关的点,在下感激不尽~

本文章给大家介绍一款不错的jQuery多级手风琴菜单实现代码,有需要了解的朋友可参考,手风琴菜单一般用于下拉导航,由于外观非常简洁,使用起来跟手风琴一样可以拉伸和收缩而得名,项目中适当应用手风琴效果会给用户带来非常好的体验

一个css与js结合的下拉菜单支持主流浏览器

 首先声明:

本人虽然在web前端岗位干了好多年,但无奈岗位对技术要求不高。html,css用的比较多,JavaScript自己原创的很少,基本都是copy修改,所以自己真正动手写时,发现基础很不牢固,边学习边实践,收获很大。

效果图:

澳门新萄京官方网站 1

不废话了,贴码了

1、css代码

 

代码如下:

a:link{color:white;text-decoration:none;}
a:visited{color:white;text-decorative:none;}
a:hover{color:white;text-decorative:none;}
a:active{color:white;text-decorative:none;}
li{float:left;display:inline;background-color:#003366;width:120px;text-align:center;margin:2px;padding:10px 0 5px 0;position:relative;}
.limouseover{background-color:#0033ff;color:red;}
.limouseout{background-color:#003366;color:black;}
li ul{display:none;width:120px;position:absolute;left:0;top:30px;}
li ul li{margin:0px auto;border-top:1px solid #006699;}

 

2、JavaScript代码

代码如下:

<script language=javascript>
function menu(menu1){
//鼠标移入移出classname切换和子菜单隐藏、显示切换。
if (document.getElementById(menu1)){
var menu_ul=document.getElementById(menu1);
if (menu_ul.getElementsByTagName("li").length){
var menu_li=menu_ul.getElementsByTagName("li");
for (i in menu_li){
menu_li[i].onmouseover=function(){this.className="limouseover";if (this.getElementsByTagName("ul").length){this.getElementsByTagName("ul")[0].style.display="block";}}
menu_li[i].onmouseout=function(){this.className="limouseout";if (this.getElementsByTagName("ul").length){this.getElementsByTagName("ul")[0].style.display="none";}}
}
}
}
}

</script>

 

3、html代码

 

代码如下:

<ul id=menu1>
<li><a href="">首页</a></li>
<li><a href="">菜单1菜单1</a>
<ul>
<li><a href="">子菜单1子菜单1子菜单1子菜单1</a></li>
<li><a href="">子菜单2</a></li>
</ul>
</li>
<li><a href="">菜单2</a>
<ul>
<li><a href="">子菜单1子菜单1子菜单1子菜单1</a></li>
<li><a href="">子菜单2</a></li>
</ul>
</li>
</ul>

<script>var menu1=new menu("menu1");</script>

 

说明:

1、考虑到ul和li页面用的比较多,可以在css前加入#menu1,以对菜单样式进行范围限制。

2、js主要是对鼠标移入和移除事件进行了侦听,对应切换到limouseover和limouseout样式;同时对子菜单的display属性进行更改,达到显示隐藏的功能。

3、同一个页面可以重复调用,不冲突,html代码中的JavaScript代码是调用实例,前面的menu1为任意变量名,括号内的menu1为html页面中的id。

本例的缺点:

1、菜单li的mouseover、mouseout和子菜单li的样式一样,即同一个颜色和字体,没有实现单独设置。

2、由于要兼容Ie6和ie7,所以其中采用position:absolute的同时,增加了left和top属性,top要根据菜单li的整体高度设定。

首先声明: 本人虽然在web前端岗位干了好多年,但无奈岗位对技术要求不高。html,css用的比较多...

文字滚动我们只要的搜索可以有千万个这个的实例,但是同一页面可以多次调用并且无缝滚动的效果不多,下面我推荐一款不错的同一页面可次调用的jquery文字无缝滚动插件应用实例,各位朋友可参考。

前言

前端技术发展很快,很多项目面临前端部分重构,很开心可以让我进行这次项目前端的重构方案编写,在思考的同时参考了网上很多资料,希望本篇重构方案有一定的完整性,可以带给大家一些在面临重构时有用的东西,同时希望路过的大牛小牛不领赐教,能给我略微指点下重构相关的点,在下感激不尽~


一、原项目梳理

效果如下

相关文章

相关搜索:

今天看啥

搜索技术库

返回首页

  • [ C# ] 判断一个类是否实现了某个接口的多种
  • ASP.NET MVC 4 的JS/CSS打包压缩功能-------过滤文件
  • asp.net使用httphandler打包多CSS或JS文件以加快页
  • [.net 面向对象编程基础] (17) 数组与集合,.
  • [ C# ] 判断一个类是否实现了某个接口的多种
  • 堆分配与栈分配---SAP C 电面(6),---sap

相关频道: HTML/CSS  HTML5  Javascript  jQuery  AJax教程  前端代码  正则表达式  Flex教程  WEB前端教程  

jquery文字无缝滚动插件,仅适合于文字,因为此效果是用不断的将第一行插入到最后来实现的,如果是比较大的内容块,会比较卡。

一、原项目梳理

首先对原来项目做一个大概的梳理,既然是重构,当然很多东西是可以继续拿来使用的。

首先对原来项目做一个大概的梳理,既然是重构,当然很多东西是可以继续拿来使用的。

澳门新萄京官方网站 2

帮客评论

源代码如下:

1.1页面结构

我这边负责的PC端的重构,所以先把页面结构及之间的关系梳理了一遍,并用xmind画好结构图,重点功能做上标记,因为vue是渐进式框架,所以我会优先重构重要的部分
xmind结构图我就不上了,职业操守还是要的

1.1页面结构

代码解析

  

1.2项目结构

项目结构是针对代码组织结构的,梳理了项目各重要的文件夹及文件并注明对应的内容或者作用。同样的,使用xmind画出结构图,xmind图略。

我这边负责的PC端的重构,所以先把页面结构及之间的关系梳理了一遍,并用xmind画好结构图,重点功能做上标记,因为vue是渐进式框架,所以我会优先重构重要的部分

HTML

 代码如下

1.3前端框架、模板

使用公司内部人员自创框架C.F.F,自定义build文件,内嵌Smarty模板获取后台数据,利用{$xxx}获取后台数据,但是定义了很多全局变量存储模板数据,造成占用更多内存、污染命名空间等问题。
定义公共组件供各模块或特定场景调用,复用度高

xmind结构图我就不上了,职业操守还是要的

首先在head间引用jQuery和插件。

复制代码

1.4第三方库、组件、插件

jquery: JavaScript库
html5shiv:用于解决IE9以下版本浏 览器对HTML5新增标签不识别,并导致CSS不起作用的问题。
Dialog : jquery弹窗插件
jCarousel : jquery 轮播插件 (重构版舍弃,原因不复杂的场景能原生实现尽量原生实现)
respond:为 IE6-8 以及其它不支持 CSS3 Media Queries 的浏览器提供媒体查询的 min-width 和 max-width 特性,实现响应式网页设计
sideToolbar:导航工具
echarts: 图形工具


1.2项目结构

 代码如下

(function($) {
  $.fn.myScroll = function(options) {

二、重构方案

项目结构是针对代码组织结构的,梳理了项目各重要的文件夹及文件并注明对应的内容或者作用。同样的,使用xmind画出结构图,xmind图略。

复制代码

    //默认配置
    var defaults = {
      speed: 40,//滚动速度,值越大速度越慢
      rowHeight: 24 //每行的高度
    };

2.1开发规范

  • 命名规范
  • html/css/less/sass/scss/javascript编码规范
  • 代码检查工具 eslint

规范这个东西没有绝对的对错,只有同公司或者同部门来制定规范大家都保持一致,同事之间能很快读懂相互的代码,提高开发效率

2.2技术选型

  • 2.2.1 开发模式:前后端分离

前后端分离开发早已成为趋势,到现在新项目大多采用这种模式进行开发,项目完全重构的话当然首选此模式
好处:以前没有前端这一职位之说,都是后端兼顾开发,数据库、底层服务、接口,页面一把梭,压力大,而且精力有限不能在每个领域都做的出色。后来有切图这一职,可以把页面写的更精美一些,通过模板和请求接口配合进行数据交互,前端都是紧紧耦合于后端,这种情况下开发,沟通成本,开发过程中进度依赖成本都是较高的。前后端分离后,分工更明确,各自专注做好自己领域的事,同时开工,不相互依赖,效率高
原理:(此图来自某博客,地址忘记。 望博主看到能联系我加上转载出处,在此抱歉~)

澳门新萄京官方网站 3
开启一个本地的服务器来运行自己的前端代码,以此来模拟真实的线上环境;
利用nodejs的express框架来开启一个本地的服务器,然后利用nodejs的一个http-proxy-middleware插件将客户端发往nodejs的请求转发给真正的服务器,让nodejs作为一个中间层。
然后就是数据问题了,后端接口在开发中,前端需要数据怎么办呢?mockjs了解一下,
API地址https://github.com/nuysoft/Mo… ,当后端设计出AP接口文档后,我们就可以利用mockjs模拟出对应格式的假数据进行开发,等到接口完全完成之后,再进行接口联调

  • 2.2.2 MVVM框架:vue

Vue是一个渐进式框架,容易入手、容易协同,能够快速灵活的开发迭代。同时也是目前主流三大框架里学习成本最低的,目前,公司也在主推vue作为首选框架,进行相关技术的培训。
Vue社区相对热度高,组件、库、轮子多,资源整合链接:https://segmentfault.com/p/12…
体积小、自由度高、脚手架创建的项目自带webpack打包构建工具
虽然vue是单页应用,但是可以通过配置webpack进行多页开发

  • 2.2.3 css预编译语言

使用css预编译语言来写css会提高编写css效率(具体提高多少百分比效率可自行测试,我觉得找一段写好的css,先用css写一遍,再用less或者其他写一遍计算耗时百分比,这里忽略写样式时候思考的时间进行测试)
预编译语言可以定义变量(比如常用的颜色、字体、字号等)、嵌套写法、可以继承其他类的属性、计算、内置函数等

  • 2.2.4 常用类库

图形工具—echarts (对应场景 – xxx)
适配插件—flexible taobaoH5终端适配方案 (对应场景—xxx)
Lodash – JS函数库 (对应场景—xxx)
ElementUI – UI库 (对应场景—xxx)
One-Page-Nav – 导航插件 (对应场景—xxx)
具体场景我就不写了,根据你们不同的业务需求去判断需要哪些类库插件之类的,预先决定好,以免半途做什么都要去花时间思考


1.3前端框架、模板

<script type="text/javascript" src="js/jquery.js"></script> 
<script type="text/javascript" src="js/accordion.js"></script> 

    var opts = $.extend({}, defaults, options),
        intId = [];

2.3构建工具

既然选择了vue框架,构建工具当然选择vue自带的webpack了,对于webpack有人说会配置项目就行,有人说要深入研究,这个看个人需求我觉得

使用公司内部人员自创框架C.F.F,自定义build文件,内嵌Smarty模板获取后台数据,利用{$xxx}获取后台数据,但是定义了很多全局变量存储模板数据,造成占用更多内存、污染命名空间等问题。

接着,在body间写上菜单主体代码,HTML代码将由一系列无序列表组成。

    function marquee(obj, step) {
      obj.find("ul").animate({
        marginTop: '-=1'
      }, 0, function() {
        var s = Math.abs(parseInt($(this).css("margin-top")));
        if (s >= step) {
          $(this).find("li").slice(0, 1).appendTo($(this));
          $(this).css("margin-top", 0);
        }
      });
    }

2.4开发效率

  • PS一键切图功能
  • emmet快速编写HTML

#page>div.logo ul#navigation>li*5>a{Item $}

1
#page>div.logo ul#navigation>li*5>a{Item $}

按下tab键,上述代码 等于

<div id="page"> <div class="logo"></div> <ul id="navigation"> <li><a href="">Item 1</a></li> <li><a href="">Item 2</a></li> <li><a href="">Item 3</a></li> <li><a href="">Item 4</a></li> <li><a href="">Item 5</a></li> </ul> </div>

1
2
3
4
5
6
7
8
9
10
<div id="page">
    <div class="logo"></div>
    <ul id="navigation">
        <li><a href="">Item 1</a></li>
        <li><a href="">Item 2</a></li>
        <li><a href="">Item 3</a></li>
        <li><a href="">Item 4</a></li>
        <li><a href="">Item 5</a></li>
    </ul>
</div>

背景:原项目写的纯css

  • less/sass/scss 快速编写css

比如

@base-size: 40px; @theme-color: #ccc; @my-selector: title; .aa { font-weight: bold; } .@{my-selector} { font-size: @base-size; color: @theme-color; margin: 100/2px 200/10px; &-ok { color: green; } &-no { color: yellow; } > li{ &:extend(.aa); &:hover { color: #fff; } } }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
@base-size: 40px;
@theme-color: #ccc;
@my-selector: title;
 
.aa {
  font-weight: bold;
}
 
.@{my-selector} {
  font-size: @base-size;
  color: @theme-color;
  margin: 100/2px 200/10px;
  &-ok {
    color: green;
  }
  &-no {
    color: yellow;
  }
  > li{
    &:extend(.aa);
    &:hover {
      color: #fff;
    }
  }
}

编译后为:

.aa, .title > li { font-weight: bold; } .title { font-size: 40px; color: #ccc; margin: 50px 20px; } .title-ok { color: green; } .title-no { color: yellow; } .title > li:hover { color: #fff; }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
.aa,
.title > li {
  font-weight: bold;
}
.title {
  font-size: 40px;
  color: #ccc;
  margin: 50px 20px;
}
.title-ok {
  color: green;
}
.title-no {
  color: yellow;
}
.title > li:hover {
  color: #fff;
}

这里只写了一点点,功能还有很多的
less官网选我选我
sass官网:选我选我

  • webpack:压缩代码、图片,合并JS,检测文件更新等自动进行
  • webstorm自带取色器(其他IDE应该都有,自行找下)

写颜色色值的地方可以点击调出取色板(不限于css),可以选颜色也可以利用吸管取色(屏幕任意处 不限于IDE内部),也有取色的网站可以收藏到书签工具文件夹里澳门新萄京官方网站 4

  • Mockjs:上面有介绍mockjs,这里不再赘述,由于本人有过手写假数据的悲惨经历,故把mockjs列入可以提高开发效率行列,因为前后端分离后前后端同时开发,假数据已成必须

比如:

let template = { 'anchorList|3-6':[{ 'id|1-100': 1, 'name': '@cname', 'date': '@date(yyyy-MM-dd)', biubiubiu: () => Mock.Random.string('abcdefghijklmnopqrstuvwxyz', 5), 'arr|2-5': [{ 'age|10-20': 0 }] }] } console.log(Mock.mock(template))

1
2
3
4
5
6
7
8
9
10
11
12
let template = {
    'anchorList|3-6':[{
      'id|1-100': 1,
      'name': '@cname',
      'date': '@date(yyyy-MM-dd)',
      biubiubiu: () => Mock.Random.string('abcdefghijklmnopqrstuvwxyz', 5),
      'arr|2-5': [{
        'age|10-20': 0
      }]
    }]
  }
  console.log(Mock.mock(template))

输出:澳门新萄京官方网站 5

 

  • 模块化、组件化开发:前后端解耦后,前端之间配合也可以解耦,各自负责不同的模块开发,写自己的组件,最后通信部分再协同

定义公共组件供各模块或特定场景调用,复用度高

 代码如下

    this.each(function(i) {
      var sh = opts["rowHeight"],
          speed = opts["speed"],
          _this = $(this);

2.5性能优化

  • 2.5.1 数据存取

☆ 尽量使用局部变量
☆ 对象成员的嵌套深度与读取时间成正比,嵌套过深要进行优化

  • 2.5.2 DOM

☆ 尽量减少DOM操作(访问和修改都算)的次数
☆ 访问元素时使用最快的API
☆ 使用事件委托来减少事件处理器的数量
☆ 减少重绘和重排的次数

  • 2.5.3 算法和流程

☆ for循环、while循环、do-whild循环比for in 要快
☆ 优化循环体的复杂度
☆ 最小化属性查找:

for(let i = 0, len = arr.length; i < len; i ){ ... }

1
2
3
4
for(let i = 0, len = arr.length; i < len; i ){
 
...
}

☆ 当条件较少时 使用if-else更易读,而当条件较多时if-else性能负担比switch大,易读性也没switch好。
☆ 对于if else 概率越大的条件越靠前判断 比如:

☆ 当计算量很大且重复的时候,用Memoization缓存计算结果

  • 2.5.4 字符串拼接

比较下四中字符串拼接方法的性能:
A:str = str ‘a’ ’b’
B:str = ‘a’ ‘b’
C: arr.join(”)
D:str.concat(‘b’,’c’)
☆ Chrome65上测试的是A优于B优于C优于D
其他浏览器不确定

  • 2.5.5 Ajax

☆ 服务端设置HTTP头信息确保响应会被浏览器缓存
☆ 客户端讲获取的信息存到本地避免再次请求(localstorage sessionstorage cookice)
☆ 设置HTTP头信息,expiresgaosu告诉浏览器缓存多久
☆ 减少HTTP请求,合并css、js、图片资源文件等或使用MXHR
☆ 通过次要文件用Ajax获取可缩短页面加载时间

这里只列了比较重要的一部分,安利一下我之前写的性能优化总结传送门

1.4第三方库、组件、插件

复制代码

      intId[i] = setInterval(function() {
        marquee(_this, sh);
      }, speed);

2.6模块化组件化

模块化:以前由CommonJs、AMD、CMD等实现,现在ES6的Module(原生模块化)完全可以取而代之,灵活、高效是模块化开发的好处,对于某个模块我想输出就输出,想引入就引入,输出引入也只需一个关键词(export/import),而且ES6模块语法支持暴露常量、单一接口、所有接口、混合暴露、取别名等等灵活高效是毋庸置疑的
配合webpack在构建的时候把资源整合打包压缩自动处理了一些以前需要手动进行的性能优化问题了
组件化:解决复杂业务的痛点,把复杂的业务分为很多个组件分开开发管理以降低开发难度和维护成本。一个5000行的页面和十个500行命名规范的组件哪个开发、维护简单?
组件灵活随加随用,可复用避免重复开发,可组合使用

jquery: JavaScript库

<ul class="nav"> 
   <li><a href="; 
   <li><a href="#">服务</a></li> 
   <li><a href="#">案例</a></li> 
   <li><a href="#">文章</a></a> 
        <ul> 
           <li><a href="#" target="_blank">XHTML/CSS</a></li> 
           <li><a href="#">Javascript/Ajax/jQuery</a> 
                <ul> 
                    <li><a href="#">Cookies</a></li> 
                    <li><a href="#">Event</a></li> 
                    <li><a href="#">Games</a></li> 
                    <li><a href="#">Images</a></li> 
                </ul> 
            </li> 
            <li><a href="#" target="_blank">PHP/MYSQL</a></li> 
            <li><a href="#" target="_blank">前端观察</a></li> 
            <li><a href="#" target="_blank">HTML5/移动WEB应用</a></li> 
        </ul> 
    </li> 
    <li><a href="#">关于</a></li> 
</ul> 

      _this.hover(function() {
        clearInterval(intId[i]);
      }, function() {
        intId[i] = setInterval(function() {
          marquee(_this, sh);
        }, speed);
      });

2.7前端安全

  • 2.7.1 XSS

XSS是指浏览器错误的将攻击者提供的用户输入数据当做JavaScript脚本给执行了
解决办法:校验用户输入,特殊字符进行转义
Vue 双花括号自带过滤功能

  • 2.7.2 本地存储数据泄露

本地存储的所有数据就都可能被攻击者的JS脚本读取到,所以敏感、机密信息都不建议在前端存储
const常量 let 块级作用域避免代码习惯不佳导致的作用域混乱问题

html5shiv:用于解决IE9以下版本浏 览器对HTML5新增标签不识别,并导致CSS不起作用的问题。

 

    });

2.8用户体验

☆ 优化加载速度,减少用户等待时间
☆ 减少不必要的无谓的操作
☆ 动画交互合理,短平快的交互或者动画更适合知学宝,我们是功能型网站不是欣赏型网站,不需要太花里胡哨的动画,那样反而增加等待时间,适得其反
☆ 更赏心悦目的UI(字体、图片、logo,按钮、列表等)
☆ 处理好很多小的细节的地方,比如… 针对项目的地方就略了

关于用户体验这块暂时没找到比较权威的书,如果大家有觉得不错的欢迎留言推荐~

Dialog : jquery弹窗插件

CSS

  }
})(jQuery);

end

写的不是很细,但愿很多地方都覆盖到了,欢迎留言补充~
注:内容有不当或者错误处请指正~转载请注明出处~谢谢合作!

1 赞 4 收藏 评论

澳门新萄京官方网站 6

jCarousel : jquery 轮播插件 (重构版舍弃,原因不复杂的场景能原生实现尽量原生实现)

当然,我们要为这个无序列表加上样式,让它非常简洁的呈现在屏幕上。

html结构如下:

respond:为 IE6-8 以及其它不支持 CSS3 Media Queries 的浏览器提供媒体查询的 min-width 和 max-width 特性,实现响应式网页设计

 代码如下

 代码如下

sideToolbar:导航工具

复制代码

复制代码

echarts: 图形工具

.nav {width: 213px; padding: 40px 28px 25px 0;}  
ul.nav {padding: 0; margin: 0; font-size: 1em; line-height: 0.5em; list-style: none;}  
ul.nav li {}  
ul.nav li a {line-height: 10px; font-size: 14px; padding: 10px 5px; color: #000; display: block; 
text-decoration: none; font-weight: bolder;} 
ul.nav li a:hover {background-color:#675C7C;    color:white;} 
ul.nav ul { margin: 0; padding: 0;display: none;}  
ul.nav ul li { margin: 0; padding: 0; clear: both;}  
ul.nav ul li a { padding-left: 20px; font-size: 12px; font-weight: normal;} 
ul.nav ul li a:hover {background-color:#D3C99C; color:#675C7C;}  
ul.nav ul ul li a {color:silver; padding-left: 40px;}  
ul.nav ul ul li a:hover { background-color:#D3CEB8; color:#675C7C;}  
ul.nav span{float:right;} 

<div class="demo">
<ul>
  <li><a title="仿webqq做的一个webos桌面效果" href="#">仿webqq做的一个webos桌面效果</a></li>
  <li><a title="图片滚动插件myScroll" href="#">图片滚动插件myScroll</a></li>
  <li><a title="使用jquery实现鼠标中键滚轮效果" href="#">使用jquery实现鼠标中键滚轮效果</a></li>
  <li><a title="如何成为网页设计专家" href="#">如何成为网页设计专家</a></li>
  <li><a title="javascript--求数组的最大最小值" href="#">javascript--求数组的最大最小值</a></li>
  <li><a title="jquery插件---图片自适应容器大小插件" href="#">jquery插件---图片自适应容器大小插件</a></li>
  <li><a title="使用css3-PIE让ie也可以支持css3" href="#">使用css3-PIE让ie也可以支持css3</a></li>
</ul>
</div>

...

jQuery

调用方法:

二、重构方案

调用accordion插件,设置相关属性,一个漂亮的手风琴效果就完成了。

 代码如下

2.1开发规范

 代码如下

复制代码

命名规范

复制代码

$(function(){
   $("div.demo").myScroll({
   speed:40,
   rowHeight:24 //行高,即li的高度,如果有margin/padding,也在计算之中
  });
});

html/css/less/sass/scss/javascript编码规范

$(function(){ 
   $(".nav").accordion({ 
        speed: 500, 
        closedSign: '[ ]', 
        openedSign: '[-]' 
    }); 
});  

代码检查工具 eslint

Accordion提供以下选项设置:

 代码如下

规范这个东西没有绝对的对错,只有同公司或者同部门来制定规范大家都保持一致,同事之间能很快读懂相互的代码,提高开发效率

speed:数字毫秒,设置菜单展开和关闭的时间。

复制代码

2.2技术选型

closedSign:当下级菜单关闭时,显示于菜单旁边的内容,可以是任意html或者text。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ";
<html xmlns=";
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
<!--
body,td,th {
 font-size: 12px;
}
a {
 font-size: 12px;
 color: #09C;
}
a:link {
 text-decoration: none;
}
a:visited {
 text-decoration: none;
 color: #09C;
}
a:hover {
 text-decoration: underline;
 color: #930;
}
a:active {
 text-decoration: none;
 color: #09C;
}
*{ margin:0; padding:0;}
.header{
 height:60px;
 background-color:#666;
 color:#FFF;
 }
.header h1{
 padding:6px 0;
 } 
.demo{
 width:300px;
 height:100px;
 overflow:hidden;
 float:left;
 margin:100px 0 0 100px;
 border:1px solid #09F;
 padding:10px;
 }
.demo ul{
   list-style:none;
   height:auto;
}
.demo ul li{
 height:24px;
 line-height:24px;
 }

2.2.1 开发模式:前后端分离

web前端学习之前端重构方案,前端重构方案了解一下。openedSign:当下级菜单展开时,显示于菜单旁边的内容,可以是任意html或者text。

-->
</style>
<script type=text/javascript src=";
<script type="text/javascript">
   (function($) {
  $.fn.myScroll = function(options) {

前后端分离开发早已成为趋势,到现在新项目大多采用这种模式进行开发,项目完全重构的话当然首选此模式

注意,如果你想菜单初始载入时就展开的话,可以在对应要展开的li上加class="active"。

    //默认配置
    var defaults = {
      speed: 40,
      //滚动速度,值越大速度越慢
      rowHeight: 24 //每行的高度
    };

好处:以前没有前端这一职位之说,都是后端兼顾开发,数据库、底层服务、接口,页面一把梭,压力大,而且精力有限不能在每个领域都做的出色。后来有切图这一职,可以把页面写的更精美一些,通过模板和请求接口配合进行数据交互,前端都是紧紧耦合于后端,这种情况下开发,沟通成本,开发过程中进度依赖成本都是较高的。前后端分离后,分工更明确,各自专注做好自己领域的事,同时开工,不相互依赖,效率高。

实例代码

    var opts = $.extend({}, defaults, options),
        intId = [];

澳门新萄京官方网站 7

 代码如下

    function marquee(obj, step) {
      obj.find("ul").animate({
        marginTop: '-=1'
      }, 0, function() {
        var s = Math.abs(parseInt($(this).css("margin-top")));
        if (s >= step) {
          $(this).find("li").slice(0, 1).appendTo($(this));
          $(this).css("margin-top", 0);
        }
      });
    }

开启一个本地的服务器来运行自己的前端代码,以此来模拟真实的线上环境;

复制代码

    this.each(function(i) {
      var sh = opts["rowHeight"],
          speed = opts["speed"],
          _this = $(this);

利用nodejs的express框架来开启一个本地的服务器,然后利用nodejs的一个http-proxy-middleware插件将客户端发往nodejs的请求转发给真正的服务器,让nodejs作为一个中间层。

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">

      intId[i] = setInterval(function() {
        marquee(_this, sh);
      }, speed);

然后就是数据问题了,后端接口在开发中,前端需要数据怎么办呢?mockjs了解一下,

<link rel="stylesheet" type="text/css" href="../css/main.css" />
<script type="text/javascript" src="../js/jquery.js"></script>
<script type="text/javascript" src="accordion.js"></script>
<script type="text/javascript">
$(function(){
   $(".nav").accordion({
        //accordion: true,
        speed: 500,
     closedSign: '[ ]',
  openedSign: '[-]'
 });
});
</script>
<style>
.demo{width:300px; margin:40px auto; padding:10px; background:#f7f7f7}
ul{list-style:none}
.nav {width: 213px; padding: 40px 28px 25px 0; font-family: "Microsoft yahei", Arial, Helvetica, sans-serif;}
ul.nav {padding: 0; margin: 0; font-size: 1em; line-height: 0.5em; list-style: none;}
ul.nav li {}
ul.nav li a {line-height: 10px; font-size: 14px; padding: 10px 5px; color: #000; display: block; text-decoration: none; font-weight: bolder;}
ul.nav li a:hover {background-color:#675C7C;    color:white;}
ul.nav ul { margin: 0; padding: 0;display: none;}
ul.nav ul li { margin: 0; padding: 0; clear: both;}
ul.nav ul li a { padding-left: 20px; font-size: 12px; font-weight: normal;}
ul.nav ul li a:hover {background-color:#D3C99C; color:#675C7C;}
ul.nav ul ul li a {color:silver; padding-left: 40px;}
ul.nav ul ul li a:hover { background-color:#D3CEB8; color:#675C7C;}
ul.nav span{float:right;}
</style>
</head>

      _this.hover(function() {
澳门新萄京官方网站,        clearInterval(intId[i]);
      }, function() {
        intId[i] = setInterval(function() {
          marquee(_this, sh);
        }, speed);
      });

API地址... ,当后端设计出AP接口文档后,我们就可以利用mockjs模拟出对应格式的假数据进行开发,等到接口完全完成之后,再进行接口联调

<body>

    });

2.2.2 MVVM框架:vue

<div id="main">
      <div class="demo">
      <ul class="nav">
         <li><a href="" target="_blank">首页</a></li>
         <li><a href="#">服务</a>
              <ul>
                  <li><a href="#">JAVASCRIPT</a></li>
                  <li><a href="#">PHP</a></li>
                  <li><a href="#">MYSQL</a></li>
                  <li><a href="#">LINUX</a></li>
              </ul>
         </li>
         <li><a href="#">案例</a></li>
         <li><a href="#">文章</a></a>
              <ul>
                   <li class="active"><a href="4.html" target="_blank">XHTML/CSS</a></li>
                   <li><a href="#">Javascript/Ajax/jQuery</a>
                        <ul>
                            <li><a href="#">Cookies</a></li>
                            <li><a href="#">Event</a></li>
                            <li><a href="#">Games</a></li>
                            <li><a href="#">Images</a></li>
                        </ul>
                   </li>
                   <li><a href="6.html" target="_blank">PHP/MYSQL</a></li>
                   <li><a href="7.html" target="_blank">前端观察</a></li>
                   <li><a href="9.html" target="_blank">HTML5/移动WEB应用</a></li>
              </ul>
         </li>
         <li><a href="about.html" target="_blank">关于</a></li>
      </ul>
   </div>
  
</div>

  }
})(jQuery);
  
   $(function(){
     $("div.demo").myScroll({
          speed:40,
          rowHeight:24
          });
     });
</script> 

Vue是一个渐进式框架,容易入手、容易协同,能够快速灵活的开发迭代。同时也是目前主流三大框架里学习成本最低的,目前,公司也在主推vue作为首选框架,进行相关技术的培训。

</body>
</html>

 
</head>
<body>
<div class="header">
<h1>jquery文字无缝滚动插件</h1>
</div>
<div class="demo">
<ul>
  <li><a title="仿webqq做的一个webos桌面效果" href="">仿webqq做的一个webos桌面效果</a></li>
  <li><a title="图片滚动插件myScroll" href="">图片滚动插件myScroll</a></li>
  <li><a title="使用jquery实现鼠标中键滚轮效果" href="">使用jquery实现鼠标中键滚轮效果</a></li>
  <li><a title="如何成为网页设计专家" href="">如何成为网页设计专家</a></li>
  <li><a title="javascript--求数组的最大最小值" href="">javascript--求数组的最大最小值</a></li>
  <li><a title="jquery插件---图片自适应容器大小插件" href="">jquery插件---图片自适应容器大小插件</a></li>
  <li><a title="使用css3-PIE让ie也可以支持css3" href="">使用css3-PIE让ie也可以支持css3</a></li>
</ul>
</div>

Vue社区相对热度高,组件、库、轮子多,资源整合链接(

jQuery多级手风琴菜单下载:

<div class="demo">
<ul>
  <li><a title="仿webqq做的一个webos桌面效果" href="">仿webqq做的一个webos桌面效果</a></li>
  <li><a title="图片滚动插件myScroll" href="">图片滚动插件myScroll</a></li>
  <li><a title="使用jquery实现鼠标中键滚轮效果" href="">使用jquery实现鼠标中键滚轮效果</a></li>
  <li><a title="如何成为网页设计专家" href="">如何成为网页设计专家</a></li>
  <li><a title="javascript--求数组的最大最小值" href="">javascript--求数组的最大最小值</a></li>
  <li><a title="jquery插件---图片自适应容器大小插件" href="">jquery插件---图片自适应容器大小插件</a></li>
  <li><a title="使用css3-PIE让ie也可以支持css3" href="">使用css3-PIE让ie也可以支持css3</a></li>
</ul>
</div>
</body>
</html>

体积小、自由度高、脚手架创建的项目自带webpack打包构建工具

...

...

虽然vue是单页应用,但是可以通过配置webpack进行多页开发

2.2.3 css预编译语言

使用css预编译语言来写css会提高编写css效率(具体提高多少百分比效率可自行测试,我觉得找一段写好的css,先用css写一遍,再用less或者其他写一遍计算耗时百分比,这里忽略写样式时候思考的时间进行测试)

预编译语言可以定义变量(比如常用的颜色、字体、字号等)、嵌套写法、可以继承其他类的属性、计算、内置函数等

2.2.4 常用类库

图形工具—echarts (对应场景 – xxx)

适配插件—flexible taobaoH5终端适配方案

Lodash – JS函数库

ElementUI – UI库

One-Page-Nav – 导航插件

具体场景我就不写了,根据你们不同的业务需求去判断需要哪些类库插件之类的,预先决定好,以免半途做什么都要去花时间思考

2.3构建工具

既然选择了vue框架,构建工具当然选择vue自带的webpack了,对于webpack有人说会配置项目就行,有人说要深入研究,这个看个人需求我觉得

2.4开发效率

PS一键切图功能

emmet快速编写HTML

#page>div.logo ul#navigation>li*5>a{Item $}

按下tab键,上述代码 等于

澳门新萄京官方网站 8

背景:原项目写的纯css

less/sass/scss 快速编写css

比如

@base-size: 40px;

@theme-color: #ccc;

@my-selector: title;

.aa {

font-weight: bold;

}

.@{my-selector} {

font-size: @base-size;

color: @theme-color;

margin: 100/2px 200/10px;

&-ok {

color: green;

}

&-no {

color: yellow;

}

> li{

&:extend;

&:hover {

color: #fff;

}

}

}

编译后为:

.aa,

.title > li {

font-weight: bold;

}

.title {

font-size: 40px;

color: #ccc;

margin: 50px 20px;

}

.title-ok {

color: green;

}

.title-no {

color: yellow;

}

.title > li:hover {

color: #fff;

}

这里只写了一点点,功能还有很多的

less官网(

sass官网(

webpack:压缩代码、图片,合并JS,检测文件更新等自动进行

webstorm自带取色器(其他IDE应该都有,自行找下)

写颜色色值的地方可以点击调出取色板,可以选颜色也可以利用吸管取色(屏幕任意处 不限于IDE内部),也有取色的网站可以收藏到书签工具文件夹里

澳门新萄京官方网站 9

Mockjs:上面有介绍mockjs,这里不再赘述,由于本人有过手写假数据的悲惨经历,故把mockjs列入可以提高开发效率行列,因为前后端分离后前后端同时开发,假数据已成必须

比如:

let template = {

'anchorList|3-6':[{

'id|1-100': 1,

'name': '@cname',

'date': '@date(yyyy-MM-dd)',

biubiubiu: () => Mock.Random.string('abcdefghijklmnopqrstuvwxyz', 5),

'arr|2-5': [{

'age|10-20': 0

}]

}]

}

console.log(Mock.mock)

输出:

澳门新萄京官方网站 10

模块化、组件化开发:前后端解耦后,前端之间配合也可以解耦,各自负责不同的模块开发,写自己的组件,最后通信部分再协同

2.5性能优化

2.5.1 数据存取

☆ 尽量使用局部变量

☆ 对象成员的嵌套深度与读取时间成正比,嵌套过深要进行优化

2.5.2 DOM

☆ 尽量减少DOM操作的次数

☆ 访问元素时使用最快的API

☆ 使用事件委托来减少事件处理器的数量

☆ 减少重绘和重排的次数

2.5.3 算法和流程

☆ for循环、while循环、do-whild循环比for in 要快

☆ 优化循环体的复杂度

☆ 最小化属性查找:

for(let i = 0, len = arr.length; i < len; i ){

...

}

☆ 当条件较少时 使用if-else更易读,而当条件较多时if-else性能负担比switch大,易读性也没switch好。

☆ 对于if else 概率越大的条件越靠前判断 比如:

☆ 当计算量很大且重复的时候,用Memoization缓存计算结果

2.5.4 字符串拼接

比较下四中字符串拼接方法的性能:

A:str = str 'a' 'b'

B:str = 'a' 'b'

C: arr.join

D:str.concat

☆ Chrome65上测试的是A优于B优于C优于D

其他浏览器不确定

2.5.5 Ajax

☆ 服务端设置HTTP头信息确保响应会被浏览器缓存

☆ 客户端讲获取的信息存到本地避免再次请求(localstorage sessionstorage cookice)

☆ 设置HTTP头信息,expiresgaosu告诉浏览器缓存多久

☆ 减少HTTP请求,合并css、js、图片资源文件等或使用MXHR

☆ 通过次要文件用Ajax获取可缩短页面加载时间

这里只列了比较重要的一部分,安利一下我之前写的性能优化总结传送门

2.6模块化组件化

模块化:以前由CommonJs、AMD、CMD等实现,现在ES6的Module完全可以取而代之,灵活、高效是模块化开发的好处,对于某个模块我想输出就输出,想引入就引入,输出引入也只需一个关键词(export/import),而且ES6模块语法支持暴露常量、单一接口、所有接口、混合暴露、取别名等等灵活高效是毋庸置疑的

配合webpack在构建的时候把资源整合打包压缩自动处理了一些以前需要手动进行的性能优化问题了

组件化:解决复杂业务的痛点,把复杂的业务分为很多个组件分开开发管理以降低开发难度和维护成本。一个5000行的页面和十个500行命名规范的组件哪个开发、维护简单?

组件灵活随加随用,可复用避免重复开发,可组合使用

2.7前端安全

2.7.1 XSS

XSS是指浏览器错误的将攻击者提供的用户输入数据当做JavaScript脚本给执行了

解决办法:校验用户输入,特殊字符进行转义

Vue 双花括号自带过滤功能

2.7.2 本地存储数据泄露

本地存储的所有数据就都可能被攻击者的JS脚本读取到,所以敏感、机密信息都不建议在前端存储

const常量 let 块级作用域避免代码习惯不佳导致的作用域混乱问题

2.8用户体验

☆ 优化加载速度,减少用户等待时间

☆ 减少不必要的无谓的操作

☆ 动画交互合理,短平快的交互或者动画更适合知学宝,我们是功能型网站不是欣赏型网站,不需要太花里胡哨的动画,那样反而增加等待时间,适得其反

☆ 更赏心悦目的UI(字体、图片、logo,按钮、列表等)

☆ 处理好很多小的细节的地方,比如... 针对项目的地方就略了

关于用户体验这块暂时没找到比较权威的书,如果大家有觉得不错的欢迎留言推荐~

end

感谢阅读

喜欢看小编文章的点个订阅或者喜欢!小编每天都会跟大家分享文章,也会给大家提供web前端学习资料。

本文由澳门新萄京官方网站发布于澳门新萄京赌场网址,转载请注明出处:web前端学习之前端重构方案,前端重构方案了解

关键词: