`
javatoyou
  • 浏览: 1070672 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

漫谈网站开发规范

阅读更多
任何一个项目或者系统开发之前都需要定制一个开发约定和规则,这样有利于项目的整体风格统一、代码维护和扩展。由于Web项目开发的分散性、独立性、整合的交互性等,所以定制一套完整的约定和规则显得尤为重要。本文档将定制一系列约定和规则,他们分别包括组件团队、文件夹命名规则、文件名命名规则、程序代码编程风格、数据库设计约定。这些规则和约定需要与开发人员、设计人员和维护人员共同讨论定制,将来开发都将严格按规则或约定开发。每个团队开发都应有自己的一套规范,一个优良可行的规范可以使我们工作得心应手事半功倍,这些规范都不是唯一的标准不存在对与错,也许有些地方与你当前使用的习惯相驳,很多地方都有争议。比如很多人习惯设计数据库时采用自动增长字段,而有些人(像我这样的人)就坚决反对,各自都有比较充分的理由阐述自己的观点,所以只好根据具体情况来采用相应的策略。
  非常明显在Web项目开发中有前后台开发之分,前台开发主要是指非程序编程部分,主要职责是网站AI设计、界面设计、动画设计等。而后台开发主要是编程和网站运行平台搭建,其主要职责是设计网站数据库和网站功能模板的实现。下面的这些规范主要是从这2个方面来定制的,这些规范是我这几年学习工作中总结的一点小经验,本文档比较适合中小型网站或者Web项目的开发规范。

  1.组建开发团队
  在接手项目后的第一件事是组建团队。根据项目的大小团队可以有几十人,也有可以是只有几个人的小团队,在团队划分中应该含有6个角色,这6个角色是必须的,分别是项目经理,策划,美工,程序员,代码整合员,测试员。也许你的团队还没有6个人,没有关系一个人可以有多个角色,比如项目经理还可以有策划这个角色,如程序员还可以含有代码整合和测试这2个角色,如果你的项目够大人数够多那就分为6个组,每个组分工再来细分。下面简单介绍一下这6个角色的具体职责。

  项目经理,项目总体设计,开发进度的定制和监控,定制相应的开发规范,负责各个环节的评审工作,协调各个成员(小组)之间开发。策划,提供详细的策划方案和需求分析。还包括后期网站推广方面的策划。美工,根据策划和需求设计网站AI,界面,Logo等。程序员,根据项目总体设计来设计数据库和功能模块的实现。代码整合员,负责将程序员的代码和界面融合到一起,代码整合员可以制作网站的相关页面,测试员,负责测试程序。

  2.开发工具
  Web开发工具主要分为3部分,第一部分是网站前台开发工具,第二部分是网站后台开发环境,第三部分是项目管理和辅助软件。下面分别简单介绍这三部分需要使用的软件。

  网站前台开发主要是指Web界面设计。包括网站整体框架建立、常用图片、Flash动画设计等等,主要使用的相关软件是:Adobe Illustrator 、Adodb Photoshop、Dreamweaver MX、Flash MX等。

  网站后台开发主要指网站动态程序开发、数据库建模,主要使用的相关软件是: PowerDesigner(数据库建模),PowerDesigner在数据库设计方面应用非常强大,用它可以快速创建数据库概念和物理模型,我最喜欢的还是它生成数据库Report的功能太方便了,设计数据库强烈推荐用它。Rational Rose(程序建模),如果你的项目功能模块不是特别复杂那就剩了它吧,这样会节省一些时间和开发的复杂度,不过我个人认为不管是大项目还是小项目都应该画画Rose图。

  网站项目管理主要指对开发进度和代码版本的控制。开发进度用Microsoft Project来制定,代码版本控制采用Visual SourceSafe,当然还有其他的选择比如CVS和Rational ClearCase。网站测试采用VS.net的附带工具Microsoft Application Center Test,它可以进行并行、负载测试等。程序文档编写采用Word,如果你非常怀旧用WPS也可以。

  3.网站开发流程
  在项目开始实施之前应该有一个工作步骤也就是工作流程,在项目开发中最需要时间的是总体设计和系统测试,而程序编写代码所占的时间并不多,但有的团队就急于开发写代码,先把程序写出来再说,没有注重评审和测试这2个环节,结果造成返工,我在一家比较大的公司中都遇到多次这种情况。所以项目来了不要急于开工写代码,应该一步一步慢慢来,只有走的慢才能走得稳走得远。图1的开发流程比较好地体现开发的整个环节。

图 1



  从图1可以看到2条主线,这2条主线分别是前台开发和后台开发。前后台开发在项目开发早期互相没有交叉,当然不是绝对没有,Web策划和需求分析都是互相有关系的,一个是网站表现形式和风格的策划另一个是网站功能的策划,它们是衣服和躯干的关系。到了开发后期就需要把界面和功能模块结合起来形成一个统一,也就即将发布的网站。

  4.数据库开发
  数据文件命名采用系统名+_+文件类型,比如系统名为kupage,则数据库文件命名为kupage_database.mdf,有的数据库文件有多个,比如SQL Server就有2个,一个是数据库文件,另一个是日志文件,那么他们的文件命名分别为kupage_database.mdf,kupage_log.log。文件名全部采用小写。

  数据库表命名规范,表名长度不能超过30个字符,表名中含有单词全部采用单数形式,单词首写字母要大写,多个单词间不用任何连接符号。若库中有多个系统,表名采用系统名称+单词或多个单词,系统名是开发系统的缩写,系统名称全部采用小写英文字符,如bbsTitle,bbsForumType。若库中只含有一个系统,那么表名仅用一个单词或多个单词。单词选择能够概括表内容的一个或多个英文单词,如UserInfo,UserType。关连表命名规则为Re_表A_表B,Re是Relative的缩写,如:Re_User_ArticleType, Re_User_FormType。

  数据库字段命名规范,数据库字段名全部采用小写英文单词,单词之间用”_”隔开,命名规则是表别名+单词,如:user_name,user_pwd。表别名规则,如果表名是一个单词,别名就取单词的前4 个字母;如果表名是两个单词,就各取两个单词的前两个字母组成4 个字母长的别名;如果表的名字由3 个单词组成,你不妨从头两个单词中各取一个然后从最后一个单词中再取出两个字母,结果还是组成4 字母长的别名。

  视图名采用规则View_表A_表B_表C,View表示视图。这个视图由几个表产生就用”_”连接几个表的名,如果表过多可以将表名适当简化,但一定要列出所有表名。

  存储过程命名规则P_表名_存取过程名(缩写),比如P_User_Del,P_ArticleType_AddData。
  SQL语句编写规则,关键字必须大写,其他书写按上述命名规则,比如:
  SELECT user_id, user_name FROM User WHERE user_id = ‘tom’

  5.文件夹文件名命名规范
  文件夹命名一般采用英文,长度一般不超过20个字符,命名采用小写字母。除特殊情况才使用中文拼音,一些常见的文件夹命名如:images(存放图形文件),flash(存放Flash文件),style(存放CSS文件),scripts(存放Javascript脚本),inc(存放include文件),link(存放友情链接),media(存放多媒体文件)等。

  文件名称统一用小写的英文字母、数字和下划线的组合。命名原则的指导思想一是使得你自己和工作组的每一个成员能够方便的理解每一个文件的意义,二是当我们在文件夹中使用“按名称排例”的命令时,同一种大类的文件能够排列在一起,以便我们查找、修改、替换、计算负载量等等操作 。

  1、图片的命名原则名称分为头尾两部分,用下划线隔开,头部分表示此图片的大类性质例如广告、标志、菜单、按钮等等。
  放置在页面顶部的广告、装饰图案等长方形的图片取名: banner
  标志性的图片取名为: logo
  在页面上位置不固定并且带有链接的小图片我们取名为 button
  在页面上某一个位置连续出现,性质相同的链接栏目的图片我们取名: menu
  装饰用的照片我们取名: pic
  不带链接表示标题的图片我们取名: title
  下面是几个范例: banner_sohu.gif 、banner_sina.gif、 menu_aboutus.gif 、menu_job.gif、 title_news.gif、 logo_police.gif、 logo_national.gif 、pic_people.jpg 。

  2、动态语言文件命名规则性质_描述,描述可以有多个单词,用”_”隔开,性质一般是该页面得概要。
  范例:register_form.asp,register_post.asp,topic_lock.asp
  6.程序代码编程规范
一个良好的程序编码风格有利于系统的维护,代码也易于阅读查错。在此只讨论ASP的编程风格和约定。在ASP中所有变量是弱变量,无需定义就可以直接使用,而且代码不区分大小写。但其他语言一般这些都要定义的,为了养成良好的编程习惯,编写代码务必按照一下规则。

  1、每个变量名必须定义,在ASP文件的最开始添加语句 <!--Option Explicit--> ,强制定制每个变量。

  2、出于易读和一致性的目的,在代码中使用以下变量命名约定:

子类型

前缀

示例

Boolean

bln

blnFound

Byte

byt

bytRasterData

Date (Time)

dtm

dtmStart

Double

dbl

dblTolerance

Error

err

errOrderNum

Integer

int

intQuantity

Long

lng

lngDistance

Object

obj

objCurrent

Single

sng

sngAverage

String

str

strFirstName



  3、程序代码需要有缩进,缩进采用键盘Tab键,不采用空格键。并且”=”或者链接字符串时需要左右空一格,如下:
   <!--<br>   strMessage = &#8220;你好&#8221;<br>   strMessage = strMessage & &#8220;你坏&#8221;<br>   -->
  4、函数过程编写的约定。函数或者过程命名采用动作+名词,每个函数需要给出相应的注释,函数功能,传入变量,以及作者和修改相关信息。如下面函数:
  <%
  '[功能] 返回一个参数的值
  '[参数] strParameterName 参数名称
  '[作者] icefire 2002/8/20 am
  Function GetParameterValue(strParameterName)
   Dim objRS, strSQL, strParameterValue
   strSQL = "SELECT ParameterValue FROM damsParameters WHERE ParameterName = '" &    strParameterName & "'"
   .
   .
   .
  GetParameterValue = strParameterValue
  Set objRS = Nothing
  End Function

  5、ASP内置对象区分大小写。如下代码片断
  strUserName = Request.Form(“UserName”)
  Set conn = Server.CreateObject("ADODB.Connection")

  6、数据库连接一个库只能有一个数据库连接文件,创建数据库对象得原则是尽可能晚地打开数据库,尽可能早地关闭数据库。创建数据库对象调用统一地创建函数。如下:
  Sub OpenConn(ByRef conn)
   Dim strDBPath, strDBConnection

   strDBPath = Server.MapPath("database/tax.mdb")
   strDBConnnection = "Driver={Microsoft Access Driver (*.mdb)}; DBQ=" & strDBPath
   Set conn = Server.CreateObject("ADODB.Connection")
   conn.Open strDBConnnection
  End Sub

  7、当一个对象不在使用时要释放对象资源,比如objFSO,objRS对象等。采用统一函数调用。函数如下:
  Sub CloseObj(ByRef obj)
   If IsObject(obj) Then
    obj.Close
    Set obj = nothing
   End If
  End Sub

  8、时间全部以字符串的形式保存到数据库中,这样做能够是日期在不同的数据库中都能良好地保存,也方便数据库地迁移。时间用14位字符串保存,日期用8位字符串保存。
分享到:
评论

相关推荐

    软件工程思想漫谈软件工程思想漫谈

    这种方法被称为“软件工程”,旨在通过规范化和系统化的方式来提高软件的质量和生产效率。 #### 二、软件工程的核心理念 - **工程化的思维方式**:软件工程强调以工程化的方式进行软件开发,包括对项目的规划、...

    研究报告--漫谈人工智能与教育变革.pdf

    【研究报告--漫谈人工智能与教育变革】 随着科技的飞速发展,人工智能(AI)已经渗透到各个领域,教育也不例外。这份研究报告深入探讨了人工智能如何在教育领域引发变革,旨在为教育创新提供理论支持和实践指导。 ...

    系统架构漫谈.pptx

    - **数据治理**:制定统一的数据标准和规范,确保数据质量。 - **数据中台**:集中管理各类数据资源,为业务提供数据分析支持。 - **数据挖掘**:运用算法模型从大量数据中提取有价值的信息。 - **数据仓库**:用于...

    漫谈云计算安全.pdf

    《漫谈云计算安全》 随着信息技术的飞速发展,云计算已成为全球范围内备受关注的技术热点,政府、企业乃至初创公司纷纷投身其中,构建自己的云服务生态。然而,与云计算的广泛应用并存的是,其安全问题日益凸显,...

    漫谈Java数据库存取技术

    标题与描述中的“漫谈Java数据库存取技术”聚焦于探讨Java领域中处理数据库存取的多种技术。本文将深入解析这些技术的核心概念、优势与局限性,以及它们如何适应不断变化的IT环境。 ### JDBC:Java数据库连接的基石...

    漫谈虚拟机技术安全 PPT

    标题:漫谈虚拟机技术安全 描述:由McAfee研究员孙冰在2008年中国软件安全峰会上发表的演讲,重点讨论了虚拟化技术的安全性,包括虚拟机产品漏洞、虚拟环境检测与反检测、硬件辅助虚拟化技术以及VMsafe等主题。 **...

    (C#)开发漫谈:关于变量的命名和属性

    在C#编程语言中,变量的命名和属性是编程实践中至关重要的部分,它们直接影响到代码的可读性、可维护性和规范性。本资源详细探讨了C#中的变量命名规则和如何有效地使用变量属性。 首先,变量命名是遵循一定的规则和...

    GUI规范漫谈

    我就来好好胡扯一番(只说方式和方法不谈具体细节,也希望为好友备课起到借鉴作用):记得之前在做开发时自己很不愿意去写文档,我的PM给推荐了一个文章,文章的名字记得不是太清楚了,大意是在说“规范不仅仅是文档...

    漫谈“架构团队”之组织架构.docx

    【漫谈“架构团队”之组织架构】 在IT行业中,架构团队扮演着至关重要的角色,它们不仅负责构建和维护技术框架,还与业务发展紧密相连。本文主要探讨架构团队的组织架构及其职责定位,以及如何在不同的组织模式下...

    图书-软件工程思想漫谈

    - **软件工程的基本定义**:软件工程是一种将系统化的、规范的、可度量的方法应用于软件的开发、运行和维护的过程,以及包括必要的文档编制在内的所有活动。 - **软件工程的目标**:提高软件产品的质量、降低开发和...

    J2EE漫谈 简单讲解下J2EE

    J2EE包含了一系列的技术和规范,如Java Servlets API、JavaServer Pages (JSP)、Enterprise JavaBeans (EJB)、Java Database Connectivity (JDBC)、Java Naming and Directory Interface (JNDI)、Java ...

    大数据漫谈系列之:大数据怎么发挥大价值_0520.rar

    标题中的“大数据漫谈系列之:大数据怎么发挥大价值”揭示了本次讨论的核心——探讨如何利用大数据实现其潜在的巨大价值。结合描述与标签“c#”,我们可以推测这可能是一个关于如何通过C#编程语言来挖掘和利用大数据...

    漫谈项目管理及其信息化.pptx

    总结来说,项目管理信息化是企业成功的关键,它涉及到与供应链伙伴的合作、产品开发、市场定位、及时交付等多个环节。通过恰当的信息化工具,企业可以提高生产力,降低成本,优化客户关系,同时强化内部管理。然而,...

    漫谈Web前端的『组件化』@郑海波.pdf

    组件化是现代Web前端开发中的一项重要技术,它有助于改善代码的组织结构、提高开发效率、以及促进代码复用。本文将详细探讨组件化的概念、意义、实现方式以及在实践中的应用。 ### 组件化概念 组件化开发在Web前端...

    品质漫谈

    在信息化飞速发展的今天,品质已经成为各行各业不可忽视的重要因素,无论是产品制造、软件开发,还是服务提供,品质都是衡量其价值的关键标准。 首先,从技术的角度看,品质涉及到的是产品的性能和稳定性。在IT行业...

    程序规划方法漫谈_连载_作者程序匠人.pdf

    2. Visio与Word:文中提到了这两个软件,这可能意味着文章讨论了如何使用Visio这样的绘图软件来帮助规划程序流程图,以及如何使用Word这样的文档编辑软件来撰写程序规范文档。 3. 流程控制结构:提到的“Switch”、...

    漫谈数字化转型,细聊企业数据管理!.docx

    - 数据治理:包括数据盘点、规范、治理和应用,确保数据的质量、安全和合规性,为企业决策提供可靠依据。 - 数据共享:打破部门间的信息壁垒,促进内部协作,提升整体效率。 - 数据应用:通过数据分析和挖掘,...

    剑破冰山++Oracle开发艺术[1].part10

    本书主要覆盖Oracle开发必备的重要知识点:数据库编程规范、Oracle开发常用工具及使用、MERGE方法、神秘的NULL和讨厌的CHAR、扩展GROUP BY、Oracle自动类型转换、Oracle分析函数、Oracle层次查询、11g R2新特性之...

Global site tag (gtag.js) - Google Analytics