爱心论坛互帮互助平面设计 网页设计 → 网站程序员如何应对web标准

分享到:

  共有3849人关注过本帖树形打印复制链接

主题:网站程序员如何应对web标准

帅哥哟,离线,有人找我吗?
小猴乖乖
  1楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 等级:小飞侠 帖子:1750 精华:30 积分:16454 金钱:27454 金币:0 魅力:9296 威望:0 登陆:335 注册:2007/4/5 13:51:22 近访:2010/8/25 14:55:41 在线:在线0天0小时0分钟.
离升级差0天20小时0分钟.
目前等级0
网站程序员如何应对web标准  发帖心情 Post By:2007/7/28 8:29:04 [只看该作者]

贴子已被锁定

 本文讨论的是在web标准普及的形势下,网站程序员的定位约叭绾斡肷杓剖ε浜峡⒎蟱eb标准的网站项目。 

  本文适合的读者是传统TABLE布局下分工不是非常明晰的程序员。

  1:学习web标准,让你的工作变得更加简单。

  web标准是大势所趋,所以作为网站程序员。你必须洗脑,必须去学习web标准。去重新认识html标签,去了解如何让程序输出页面需要的代码。

  比如:

图片点击可在新窗口打开查看

  上边是美工出来的效果图,下边是符合标准的程序代码:

  Dim oHtml
  set rs=server.createobject("adodb.recordset")
  Sql = "select top 10 id,Title From tbl_News  order by id desc"
  rs.open sql,conn,1,1
  oHtml="<ul>"
  do while not rs.eof
  oHtml=oHtml & "<li><a href=""shownews.asp?id=" & rs("id") & """ title=""" & rs("title") & """>" & rs("title") & "</a></li>"
  rs.movenext
  loop
  oHtml=oHtml & "</ul>"
  rs.close
  set rs=nothing
  response.write (oHtml)

  而如果是传统的TABLE布局下,程序员要写的HTML代码就会多很多,要写出TABLE、要判断什么时候输出TR来换行、要在每条新闻的前边加个一个IMG来输出小图标、要用程序去控制输出的标题长度。所有的工作都需要先出页面代码,程序员才能去写出这段程序。
  对于程序员而言,你应该把web标准当成是一种福音,你应该把它当圣经一样去读,去了解页面代码到底需要什么,明白之后你就会发现。你比以前要轻松多了。由于web标准注重的是表现与内容相脱离,而程序只负责内容数据。从此你就不再需要考虑用程序代码如何控制隔行换色、一行分几列输出等等。你需要去做的,就是向页面输出最直接的内容,没有任何装饰的内容。
  当然如果你是用.net开发的话,你就可以更彻底一点了。你可以完全将工作重点放在建立对象、类库、数据访问等,向表现层提供方法即可。下边的例子是我以前做项目的,应该有点参考价值。

  2:网站程序员,别让HTML标签阻挡了你的视线。

  如果你觉得你真的非常讨厌繁琐的HTML标签,而且自己的学习方向也不在网站的表现层,那你就和HTML标签彻底地说再见吧。

  我曾经在传统桌面软件开发的公司工作,程序员都不会HTML,网站项目紧的时候又不得不让他们来帮忙。我们就拿着Visual Studio .Net 2003自带的几个例子仔细分析,按照面向对象的结构化分层开发模式,也能非常好的进行配合。以新闻模块的开发为例:
  第一步:网站程序员可以按需求分析进行数据库设计,你可以负责建表、编写存储过程。这类的事情程序员都非常的熟悉。
  第二步:定义对象。将网站的信息对象化,比如:

  Public Class News
  Protected _id As Integer
  Protected _typeId As Integer
  Protected _title As String
  Protected _author As String
  Protected _original As String
  Protected _updateTime As DateTime
  Protected _content As String
  Protected _clickCount As Integer

  Public Property Id() As Integer
  Get
  Return _id
  End Get
  Set(ByVal Value As Integer)
  _id = Value
  End Set
  End Property

  Public Property TypeId() As Integer
  Get
  Return _typeId
  End Get
  Set(ByVal Value As Integer)
  _typeId = Value
  End Set
  End Property

  Public Property Title() As String

  End Property

  Public Property Author() As String

  End Property

  Public Property original() As String

  End Property

  Public Property UpdateTime() As DateTime


 回到顶部
帅哥哟,离线,有人找我吗?
小猴乖乖
  2楼 | QQ | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 等级:小飞侠 帖子:1750 精华:30 积分:16454 金钱:27454 金币:0 魅力:9296 威望:0 登陆:335 注册:2007/4/5 13:51:22 近访:2010/8/25 14:55:41 在线:在线0天0小时0分钟.
离升级差0天20小时0分钟.
目前等级0
  发帖心情 Post By:2007/7/28 8:29:29 [只看该作者]

 End Property

  Public Property Content() As String

  End Property

  Public Property ClickCount() As Integer

  End Property
  End Class

  就像这样,把网站里所有的表都试着对象化。然后再定义对象相关的记录集,上边定义的是单个的新闻对象,再定义一个新闻的记录集。

  Public Class Newss
  ......
  End Class

  第三步:定义一套公共的数据访问方法。
  定义一些操纵数据库、执行存储过程的公共方法。
  第四步:编写基于对象的方法层。如:

  Public Function ReadNews(ByVal ID As Integer) As News

  End Function

  函数返回的就是一个新闻对象。根据功能的需要,一般还会定义一些相关的函数,如:

  '读取新闻列表
  Public Function ReadNewss(ByVal newsType As eNewsType, ByVal nCount As Integer) As News

  End Function
  '增加一新闻
  Public Function InsertNews(ByVal n As News) As Integer

  End Function

  '更新一条新闻
  Public Function UpdateNews(ByVal n As News) As Integer

  End Function

  '删除一条新闻
  Public Function DeleteNews(ByVal ID As Integer) As Integer

  End Function

  这样来做,究⒖梢苑殖啥韵蟛恪⑹莘梦什恪⒎椒ú恪⒈硐植恪6绦蛟痹蛑恍枰峁┍硐植闼枰姆椒āU庋焕矗诒硐植阈枰允拘挛帕斜硎保趁嫔杓剖χ恍枰?net中的Repeater控件,如下代码:

  <asp:Repeater ID="topNewsList" runat="server" >
  <HeaderTemplate>
  <ul>
  </HeaderTemplate>
  <ItemTemplate>
  <li><a href="shownews.asp?id=<%#Container.DataItem("id")%>"><%#Container.DataItem("title")%></a></li>
  </ItemTemplate>
  <FooterTemplate>
  </ul>
  </FooterTemplate>
  </asp:Repeater>

  而在表现层的程序代码中我们只需要加上:

  topNewsList.DataSource = New facade.newsFacade().ReadNewss(eNewsType, newsCount)

  这样的话,程序员基本上可以与HTML完全脱离了。而且这样的话,整个项目组的成员都可以并行工作了。能非常明显地提高整个项目的开发效率。况且现在web2.0模式的兴起,对后台数据库开发提出了更高的要求。如豆瓣网、365Kit等网站,后台的数据库挖掘工作是非常复杂的。所以在分工明晰的今天,除了HTML代码,其它有很多更重要的工作等待网站程序员去做。

  3:以用户为中心的设计,离不开前端开发工程师。

  如果你觉得脱离了熟悉的HTML代码,你有点舍不得的话,不要紧。干脆将自己推到web技术的风口浪尖。做一个成产品设计关系密切的前台开发工程师。

  随着网络、计算机硬件设施的不断提升,我们正在朝着富客户端的方向前进。为了产品的易用性,给网站程序员提出了非常高的要求。前台开发工程师这个岗位也越来越显得重要。这个职位应该说也是近年才有的,而这个职位也不是一般的网页设计师能胜任的,所以网站程序员也自然分开了,分后台开发工程师和前台开发工程师,这个方向应该说也是一个非常好的选择。而这个则需要你对web标准有一个比较全面的认识。既需要你对javascript非常了解,同时也需要你对DOM文档对象模型、CSS表现层样式代码、ajax异步都非常了解。相关的例子就非常多了,比如:在线注册表单的即时检测、密码强度的提示、多级下拉菜单的联动等。对于改善用户体验、提高网站访问速度都有非常重要的作用。

 


 回到顶部