上周末(2016/07/31)去了一个技术沙龙学习前端相关的东西,下面是各个主题我印象比较深的。

React + Redux 最佳实践

主题:本次分享,主要从React/Redux相关概念及其工具链,Webpack构建流程,如何Mock数据,如何测试以及一些开发小经验等方面,分享介绍如何使用React/Redux开发一个前后端分离的企业级应用系统。

有意思地方:

1. 规范化

通过开发工具进行代码校验,统一编码风格。

统一的ES6写法(这个见仁见智)。

2. JavaScript测试

进行JavaScript,介绍了测试工具。

  • jsdom(构建符合W3标准的DOM)

  • mocha(JS测试框架)

  • chai(Node BDD/TDD 断言库)

  • enzyme(airbnb出的React测试工具)

  • isparta(ES6代码测试覆盖率工具)

  • nock(HTTP 模拟库)

  • redux-mock-store(用于测试异步请求或中间件时,模拟store)

  • sion(用于JavaScript的测试监视(spy)、桩(stub)和仿制(mock)功能)

JavaScript to Native

主题:分享目前 JavaScript 编写 Native App 的现状,围绕 React Native 和 Weex 展示 JavaScript 编写原生应用的开发和调试,并讲解其中的一些原理。

有意思地方:

1. 将页面转成原生界面

这个还在理论实践的阶段,原理是页面DOM转成Virtual DOM(虚拟DOM)再而转成原生组件。

PS:有趣是有趣,但未有实践产物,难想象实践效果。(个人觉得东西没做出来就急于分享着实不好)

零配置前端开发流程

主题:Web 技术没有独裁者控制,野蛮发展导致开发环境特别混乱。不同的工具由不同的群体维护,各玩各的,常会有兼容性的问题。一个 “现代化” 的前端项目前后可能需要花费 10%~15% 的精力维护项目构建的配置,非常浪费时间。在这个分享主题我会示范一个的前端开发流程,把花在配置的时间趋于 0。

有意思地方:

1. 使用的前端框架或工具

浏览器,移动端,后台NodeJS,同构

npm vs bower vs systemjs vs duo

grunt vs gulp vs browserify vs webpack vs rollup

less,sass,postcss,css-module

ES3,ES5,ES6,ES2016

TypeScript,FlowType

React,Angular,VueJS

PS:用的都是有逼格、新的东西。

使用 Meteor + React 进行快速的原型开发

主题:主要介绍 Meteor 框架的特点,如何使用 Meteor 为 React 提供类似 Redux 的前后端数据流控制,什么是 Reactive Programming,如何实现 Optimistic UI,还有基于 websocket 编程,以及 Meteor 的现状和未来。

有意思地方:

1.  Reactive Programming

Reactive响应式(反应式)编程 是一种新的编程风格,其特点是异步或并发、事件驱动、推送PUSH机制以及观察者模式的衍生。reactive应用(响应式应用)允许开发人员构建事件驱动(event-driven),可扩展性,弹性的反应系统:提供高度敏感的实时的用户体验感觉,可伸缩性和弹性的应用程序栈的支持,随时可以部署在多核和云计算架构。

PS:简单说就是数据的交互是通过websocket进行实时交互。

概念可参考:http://www.jdon.com/idea/js/rxjs.html

React前后端同构实践

主题:本次分享我们在使用react+redux过程中遇到的一些性能瓶颈,我们在解决前后端代码/API复用、提升工作效率和前后台架构调整中所做的一些尝试及成果。

有意思地方:

1. 同构的思想

同构 JavaScript 应用基于 JavaScript 编写,可以在客户端和服务端运行。正因为此,你只需要写一次代码,就可以在服务端渲染静态页面,还可以在客户端完成复杂的交互。

服务端渲染的页面可以很好解决两个问题:

(1). 性能

因为相对于静态页面,SPA 需要更多的客户端代码,需要下载数据的体积也更大。这使得手机加载速度很慢,可能会导致一些极端的状况 —— 比如糟糕的用户体验以及收入上的损失等。依据 Microsoft 的一篇文章 ——

PS:Bing 的一项研究表明:页面的加载时间每增加 10ms,站点年度总收入就会减少 $250K。

(2). SEO

因为单页面应用依赖于 JavaScript 的执行,服务器不会提供它们可能用到的任何 HTML 内容。因此,web 爬虫很难去索引到这些页面。爬虫就是可以像 web 服务器发送请求,并且将结果分析成原始文本的程序,而不需要像一个浏览器运行 JavaScript 那样解释和执行客户端的内容。不久前,Google 优化了搜索引擎的 web 爬虫,现在它也可以抓取基于客户端 JavaScript 所构建的页面了。但是 Bing、Yahoo 以及其他搜索引擎怎么办?一个好的索引对任何公司来说都至关重要,它通常会带来更多的流量以及更高的回报。

2. 首屏加载速度方式

检测首屏加载速度,分加载模块进行优化,提高首屏加载速度,减少用户等待时间。

总结

讲的绝大多数跟React相关,看来他们是非常推崇这个框架,非常提倡组件化的开发思路。除去React的不说,我觉得比较重要的是JS测试方面,这方面我们有待加强。代码规范和工具使用都是老生常谈的,这点不用多讲。最后有一点也必须特别注意是,前端在不断发展,新的好的框架或JS版本,可以考虑使用,让代码写得更优雅。

Techparty-广州Javascript技术专场(学习分享)的更多相关文章

  1. 【重磅资料】ArchSummit全球架构师峰会·2019华为云技术专场资料下载

    ArchSummit全球架构师峰会是InfoQ中国团队推出的重点面向高端技术管理者.架构师的技术会议,54%参会者拥有8年以上工作经验.ArchSummit聚焦业界强大的技术成果,秉承"实践 ...

  2. JavaScript Shell学习分享

    目录 JavaScript Shell学习分享 简介 安装 使用原因 小结 JavaScript Shell学习分享 简介 JavaScript Shell是由Mozilla提供的综合JavaScri ...

  3. 细数Javascript技术栈中的四种依赖注入

    作为面向对象编程中实现控制反转(Inversion of Control,下文称IoC)最常见的技术手段之一,依赖注入(Dependency Injection,下文称DI)可谓在OOP编程中大行其道 ...

  4. 开源大数据技术专场(上午):Spark、HBase、JStorm应用与实践

    16日上午9点,2016云栖大会“开源大数据技术专场” (全天)在阿里云技术专家封神的主持下开启.通过封神了解到,在上午的专场中,阿里云高级技术专家无谓.阿里云技术专家封神.阿里巴巴中间件技术部高级技 ...

  5. GMTC2019会后:做一场冷门的技术专场是什么体验

    上周四(6.20)GMTC2019大会的第一天,很荣幸作为「UI与图形渲染」专场出品人获得了与图形领域几位技术专家同场交流的机会. 图形技术在前端范畴内是一个相对小众的话题,虽然前端工程师几乎每天都在 ...

  6. django之JavaScript的简单学习2

    前言:ajax预备知识:json进阶 1.JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.JSON是用字符串来表示Javascript对象: 请大家记住一 ...

  7. (转)探讨:ASP.NET技术的学习顺序问题

    探讨:ASP.NET技术的学习顺序问题 摘要:很多人对于ASP.NET的入门和学习顺序比较迷茫,今天让我们一起来跟随作者的思路学习探讨ASP.NET的学习顺序问题,希望有所帮助. 如果你已经有较多的面 ...

  8. 【转】手把手教你读取Android版微信和手Q的聊天记录(仅作技术研究学习)

    1.引言 特别说明:本文内容仅用于即时通讯技术研究和学习之用,请勿用于非法用途.如本文内容有不妥之处,请联系JackJiang进行处理!   我司有关部门为了获取黑产群的动态,有同事潜伏在大量的黑产群 ...

  9. Excel阅读模式/单元格行列指示/聚光灯开发 技术要点再分享

    1. 引言 文题中所谓技术要点再分享,本意是想在大神Charltsing Liu的博文“简单介绍Excel单元格行列指示的实现原理(俗称聚光灯功能)”的基础上写一点个人开发体会.写本文的初衷有三点,一 ...

随机推荐

  1. VMware Tools安装小结

    背景介绍:在VMware上装完ArchLinux后,窗口太小,操作不方便.查询后得知VMware Tools没有自动安装,需要手动安装. 官方安装说明:在 Linux 虚拟机中手动安装或升级 VMwa ...

  2. Sql Server系列:聚合函数

    1 SUM SUM是一个求和函数,返回指定列值的总和.SUM 只能用于数字列. 其中忽略 Null 值. 语法 SUM ( [ ALL | DISTINCT ] expression ) OVER ( ...

  3. 【WP 8.1开发】如何动态生成Gif动画

    相信如何为gif文件编码,很多朋友都会,而难点在于怎么让GIF文件中的帧动起来,也就是创建gif动画. Gif文件编码方法 先简单介绍一下编码的方法. 1.调用BitmapEncoder.Create ...

  4. 详解jquery插件中;(function ( $, window, document, undefined )的作用

    在jquery插件中我们经常看到以下这段代码 1 2 3 ;(function ( $, window, document, undefined ){ //函数体内具体代码 })(jQuery, wi ...

  5. 用js实现放大镜的效果

    第一次发博客,还有点小激动,本人现在正在天津上大学,希望以后从事前端这一行业,学习的时间不长,写博客为了记录自己的学习过程和收获,当然也算是巩固.可能写的东西不会像大牛那样高大上,只是一些基本的内容, ...

  6. UWP开发之Mvvmlight实践三:简单MVVM实例开发(图文详解付代码)

    在做MVVM各种框架对比之前,我觉得有必要先自己做一个简单的MVVM实现案例比较好,这样就可以看到自己实现的时候有那些不方便的地方.而各种框架又是怎么解决我们这些麻烦的. 案例介绍:用户登录画面,没有 ...

  7. EntityFramework 7 Join Count LongCount 奇怪问题(已修复)

    问题说明: 博客问题纪录 Use EF7, Linq Join Count is error EF7 Code Commit EF7 版本(注意 rc): 旧版本:"EntityFramew ...

  8. 小菜学习Winform(一)贪吃蛇

    前言 说到贪吃蛇,大家可能小时候都玩过,小菜最近在整理Winfrom的学习系列,那我觉得有兴趣才会有学习,就从这个小游戏讲起吧. 实现 其实我刚开始学习编程的时候,感觉写个贪吃蛇的程序会很难,因为涉及 ...

  9. 改用C++生成自动化数据表

    改用C++生成自动化数据表 前面的文章中,我们讨论了使用一个基于.NET的第三方程序库来从程序中来生成数据表.在我看来,这整个思路是非常有用的,例如为显示测试结果.我经常会自己在博客中尝试各种像这样的 ...

  10. c 语言的位运算符复习

    转载和修正,原文连接:http://www.cnblogs.com/911/archive/2008/05/20/1203477.html 位运算是指按二进制进行的运算.在系统软件中,常常需要处理二进 ...