Upgrade to Pro — share decks privately, control downloads, hide ads and more …

PyCon2014China-Zhuhai-pythonic front-end

Zoom.Quiet
November 17, 2014

PyCon2014China-Zhuhai-pythonic front-end

Zoom.Quiet

November 17, 2014
Tweet

More Decks by Zoom.Quiet

Other Decks in Technology

Transcript

  1. B/S 模型: Thin Client 服务器 浏 览 器 输出 Html

    、 Css 、 js 等 渲染展示 发起 http 请求 用户操作 输入输出终端
  2. 减少语言 • Nodejs :后端也用 js 来开发 • 曾经的 KSS :用类似

    css 的语法写 JS • PythonJS : – 浏览器上 Python 开发 – 翻译为 JS – 玩具性质
  3. 还好有前端框架 • Twitter Bootstrap • Semantic UI • JQuery UI

    • 国内的 – 淘宝 BUI – 百度 BlendUI – …
  4. 单页面应用模型: Fat Client 服务器 SPA (浏览器) 输出 json 数据 渲染展示

    发起 http 请求 API 用户操作 单页面应用 服务接口 SPA : Single Page Application ,单页面 web 应用
  5. GWT • 用 java 开发 web 前端:编译为 js • RIA

    :全端 • 回到桌面时代 • Google Adwards, Google Wallet • 问题: – 搜索引擎不友好 – 位置逐渐被 Dart 取代
  6. Dart: 替代 JS • 语言更干净 • 自带开发工具 • 支持 polymer

    组件化开发 • 一种语言,支持前后端 • 可编译为高效的 js ,支持各种浏览器 • 快速进入语言排行前 20
  7. Polymer: Web Component 实现 • W3C web 组件技术规范 – Custom

    Element – Template – Shadow DOM – HTML import • 实现: Polymer • 代表 web 未来 • 是终点吗?
  8. 作为一个开发平台 • 解放开发者 – 专注业务需求 – 少折腾技术 – 技术延续性 •

    目标: – 力求最简 – 三脚猫功夫,也能开发 – 快速开发 – 屏蔽实现细节
  9. 尝试过 backbone • 当年 Zope 时代的感觉 • 泥潭里挣扎 • 3

    个月,完成前端框架 • 革命成本太高 • 放弃
  10. 易度前端 : Fit Client 易度 Web Player 浏览器版 易度 Mobile

    Player 移动版 易度 Mobile Player 移动版 易度应用 Python 渲染 UI 组件 接受 View 指令 易度 Player :不胖不瘦,刚好 事件处理 事件处理 Web 适配 移动 适配 完全用 Python 写应用
  11. 分层:前端引擎和应用 易度 Player (前端引擎): 20% • javascript • 基础 –

    整体外观风格 – 栏目导航 – 加载进度 – 出错处理 • 动态 – 组件渲染展示 – 交互事件触发 – 界面行为控制 易度应用: 80% • python • 输出 UI 界面 • 交互事件处理 • 控制界面行为
  12. 前端引擎和应用 前端框架 前端框架 UI VIEW 各种 业务应用 (Python) 应用层 WebPlayer

    引擎层 招一个 NB 的前端维护引擎即可 前端技术革新,只需升级引擎层
  13. 使用 UI 组件 ui.panel()\ .add(ui.button(‘Click me’)\ .add(ui.text(‘Hello, world’))\ + ui.button(‘

    新增’ )\ .icon(‘add’)\ .loading(‘ 正在提交… .’)\ .on(‘click’, ‘@zopen.test:test’)
  14. View 指令集 • view.message(‘ 出错了’ , type='error', ) • view.modal(form,

    width=600) • view.layout.main().set_content(form) • view.layout.right().set_content(form)
  15. 组件选择 (DOM) 和操作 # 向 Web Component 致敬 view.closest('tabs')\ .active_panel()\

    .set_content(ui.h1(‘hello, world’)) view.find('tree#leftnav')\ .expand()
  16. Python 就是一种 DSL • Python 的表达能力,不比 html 差 • Bootstrap

    版本升级,重写 html 工程浩大 • Python 写界面,与具体实现隔离
  17. 回归桌面开发模式 • 一切皆 python – 学习更简单 – 几乎不用懂 web –

    全端开发 – 更容易 code review • 组件化开发:为 web 未来同步 • 事件驱动:屏蔽网络 • 部分的图形化开发:可以更多
  18. 引擎分离的额外收获 • 前端需求变得简单 • WebPlayer 引擎实现并不复杂 • 不再需要 MVC 框架

    • 对前端新技术,不再焦虑 • 现有前端积累得以延续 • 未来升级更加平滑
  19. 开源了吗? • 未开源 • 一种思想,很容易实现 • 目前只实现的 web 版本 –

    UI  html – VIEW  转换 JS • 想过基于 QML 的 QT 版本