使用XAML技术的平台目前包括WPF,Silverlight,Windows8等平台,未来的Windows10统一Windows App也使用XAML技术。

前端开发指通过可视化集成开发环境进行用户界面的设计和实现,结合手动编写XML界面描述代码,完成表现层开发的过程。基于XAML技术的前端开发使用的开发环境是Blend,输出是XAML代码。由于目前版本的Blend 2013存在一些问题,需要和VS配合使用。Blend 2015进行了重大改进,较好地解决了各种问题,但还未发布正式版。

下面总结一下理想的基于XAML技术的前端开发方法,部分流程在小范围内进行了尝试和推广,效果还可以,还需全面尝试和推广。

1.  该部分工作的输入是原型和需求。

原型推荐使用Axure RP或Prototyper(该软件对移动开发的支持较好)来制作,非程序员(如产品经理,UI设计师等),可以方便地绘制界面元素并使用可视化的方法表达交互逻辑。

2.  该部分工作的输出是,a. Style层代码,b. View层代码,c. 样式设计文档,d. View和ViewModel层契约-数据绑定接口文档(与后端人员协商编写)。

样式设计文档和数据绑定接口文档,推荐使用UML的方式表达,因为样式和数据皆为层次结构,存在继承和依赖关系,所以UML表达方式最为合适,推荐使用Visio绘制UML图。

Style层和View层主要使用Blend完成,尽量多地使用可视化开发方法,尽量减少手工编写XAML的工作量。

3.  分析原型,理解需求。

全部前端开发人员都要深入理解需求,连要做什么和为什么做都不清楚,是做不好界面设计和实现的。

4.  开会讨论全部原型和需求中的问题,确定无问题,达成一致的理解。

这里可以认为是第0个里程碑,即前端开发工作的起点,所有人都对需求有了一致的理解,尽量避免以后的争论。

5.  讨论整体设计风格和页面结构的设计。

在这个会上可以用头脑风暴的方式根据原型构思页面的细节展示方式,一般使用几层嵌套结构,确定使用几种标题,几种正文,几种主要字体,字号,颜色等。由一个人在Visio中用UML表达清楚,便于以后使用。这其实是制定了初步的标准,以后大家都要遵守。

6.  根据上一步的讨论,一部分人编写样式设计文档并完成Style层底层的代码。另一部分人针对关键部分出几张PS效果图。两部分要能对应。

7.  第一个里程碑,效果图确认

效果图需要领导确认。

8.  效果图修改,同时可创建全部空页面和样式文件的框架,描述各个文件都是干什么用的。

如果使用自定义的界面框架,需引入界面框架并依据框架搭建页面结构。

9.  完成全部页面的控件选用和外层布局(可加入颜色指示),可以把绘制了效果图的页面进一步美化,加入Border等元素,设置并抽取样式放入Style层。

10. 第二个里程碑,控件和布局确认。

需要后端人员确认所用控件以及预想的交互逻辑后端人员是否能够实现。

11.  修改控件问题和不合理的布局,优化布局。

12.  完成全部页面的控件内部模板,样例数据,绑定设置。

13.  第三个里程碑,页面确认。

此时包含全部功能的白页面已经完成,需要项目负责人确认所有页面的功能。

14.  数据绑定接口文档应该已经完成,页面已经可以和后端配合,联调测试。

15.  应用前期抽取的样式到全部页面,进一步设置并抽取样式到Style,完善Style层。

注意人员之间的配合,保证一致性。

16.  进入控件内部模板的修改阶段,深度修改并抽取Style。

可从易到难,内部模板的修改也要抽取样式,保证一致性。

17.  进一步完善控件内部模板的动态效果。

如鼠标移上,按下,选中等状态时的样式,可加入动画提升效果。

18.  可以完成预想的动画或考虑加入动画提升效果。

19.  如已接入真实数据,自测,互测,包括不同窗口大小,分辨率,不同真实数据下的情况,记录BUG。

20.  修改BUG。

基于微软XAML技术的前端开发方法的更多相关文章

  1. 基于微软平台IIS/ASP.NET开发的大型网站有哪些呢?

    首先说明一下,本文绝不是要说Microsoft平台多么好,多么牛.只是要提醒一些LAMP/JAVA平台下的同志们,微软平台不至于像你们说的,和想象的那么不堪!只是你们自己不知道而已.同时,也希望广大M ...

  2. 植入式Web前端开发方法

    上一篇,我讲述了植入式Web前端开发的基本情况,本篇就来探究其开发方法.以下假定CMS只能植入前端代码,并且需求规模是任意大小的. 代码形式 HTML代码是直接植入的毫无疑问,但除非植入的代码非常简短 ...

  3. 基于微软平台IIS/ASP.NET开发的大型网站有哪些?

    首先说明一下,本文绝不是要说Microsoft平台多么好,多么牛.只是要提醒一些LAMP/Java平台下的同志们,微软平台不至于像你们说的,和想象的那么不堪!只是你们自己不知道而已.同时,也希望广大M ...

  4. (转)基于微软平台IIS/ASP.NET开发的大型网站有哪些?

    首先说明一下,本文绝不是要说Microsoft平台多么好,多么牛.只是要提醒一些LAMP/JAVA平台下的同志们,微软平台不至于像你们说的,和想象的那么不堪!只是你们自己不知道而已.同时,也希望广大M ...

  5. react基于nodejs简单的搭建与开发方法

    只需安装babel命令,即可将react的jsx写法转换成浏览器认识的js写法 1.安装nodejs(百度下载安装即可,自带npm) 2.cmd打开命令行,cd进入在自己的文件夹下 执行命令: npm ...

  6. Web前端开发中的MCRV模式(转)

    作者: izujian  来源: baiduux 摘要:针对前端开发中基于ajax的复杂页面开发所面临的代码规模大,难以组织和维护,代码复用性.扩展性和适应性差等问题,本文尝试以MVC思想为 基础,结 ...

  7. Torque:轻应用背后的大蓄势 微软语音技术厚积薄发​

    Torque,为中国用户而来 此前,"微软车库"公开发布了一系列小而美的产品,它们全部由具有"极客创新"精神的微软员工在工作之外的时间构思和开发.Torque就 ...

  8. web前端开发浅析

    原文地址:http://www.cnblogs.com/babyzone2004/articles/1807381.html 摘 要:前端开发作为一项新的领域,经历的时间随然较短,却显示了强大的生命里 ...

  9. Web前端开发(高级)下册-目录

    多媒体与绘图 多媒体音频格式视频格式 HTML5多媒体支持 <audio>和<video> htmlaudioElement和htmlVideoElement <audi ...

随机推荐

  1. XSS获取cookie并利用

    获取cookie利用代码cookie.asp <html> <title>xx</title> <body> <%testfile = Serve ...

  2. [转]jQuery 读取 xml

    XML 文件内容: <?xml version="1.0" encoding="UTF-8"?> <stulist> <stude ...

  3. Codeforces Round #474-B(贪心)

    一.题目链接 http://codeforces.com/contest/960/problem/B 二.题意 给定三个数字$N, k1, k2$,接下来给出两组数$a[]$和$b[]$,每组数$N$ ...

  4. 【POJ】1062 昂贵的聘礼 (最短路)

    题目 传送门:QWQ 分析 最短路显然,但不好搞地位等级..... 地位等级不好搞?那么就暴力.. 枚举我们允许的地位等级,跑最短路. 所以$ n^2logn $出100什么鬼啊,很有迷惑性啊 还有4 ...

  5. [saiku] 通过管理台配置用户、schema和数据源

    上一篇讲到了如何下载和安装saiku [http://www.cnblogs.com/avivaye/p/4877680.html] 本文简介下saiku用户的配置操作和需要注意的点 一.添加用户 S ...

  6. Django UrL 解析

    Django的路由系统 URLconf 本质是URL与要为该URL调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于客户端发来的某个URL调用哪一段逻辑代码对应执行. 1.1 djan ...

  7. sed你所不知道的语法

    测试内容

  8. Jenkins是什么?

    Jenkins 是一个可扩展的持续集成引擎. 主要用于: l 持续.自动地构建/测试软件项目. l 监控一些定时执行的任务. Jenkins拥有的特性包括: l 易于安装-只要把jenkins.war ...

  9. VB指针操作和消息钩子

    二.VB怎么用指针       要想弄明白VB怎么使用指针,就必须要弄明白两件事,第一,如何取得数组的指针,第二,如何将指针所指向的数组取出来.       A.在讲解这两个问题之前,我们需要了解几个 ...

  10. tomcat没有发布maven项目依赖的本地jar包

    建立springMVC的maven项目,平时使用的jar包都是在pom.xml文件配置依赖关系, maven会自动从仓库中下载,这样使用tomcat部署发布都没有问题.但有时我们需要使用maven仓库 ...