zoukankan      html  css  js  c++  java
  • ASP.ASP.NET应用模板采用

    初学ASP,程序是能勉强写出来了,但若每进行一次网站页面的改版,所有的源程序都将进行一次移植手术。为此所耗费的人力精力不计其数,甚至一不小心得不偿失、前功尽弃。

    所以,梦想着那么大段的程序代码变成几个简单的字符代替,这样只要设计好页面把该功能插入就OK了。其实这也简单,只需将实现该功能的程序代码做成子程序,然后主页调用就可以了。

    很多时候,在博客中国,你会选择到很多的模板,甚至有可能自己来设计;或者采用猪飞飞BLOG的各大站长都将其站点改得不近相同……这些,我们都归功于ASP采用模板的功能。

    那下面偶就借花献佛,将模板拿来分析,以馈各位朋友。

    首先,模板需要在线修改,则应采用数据库保存模板代码

    所谓的模板,就是设计完工的标准的HTML代码,其中需要由程序实现的功能部分将采用特殊字符串代替。然,这些特殊字符串需要在显示的时候被编译为对应的功能。

    1,设计数据库testmb.mdb
    新建表moban:字段m_id(自动编号,主关键字);字段m_html(备注类型)

    2,假设第一模板内容代码

    将下列代码拷贝到m_html字段中

    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
    <title>testmb</title>
    </head>
    <body leftmargin="0" topmargin="0">
    <table width="100%" height="100%" border="0" cellpadding="5" cellspacing="2">
      <tr align="right" bgcolor="#CCCCCC"> 
        <td height="20" colspan="2">$cntop$</td>
      </tr>
      <tr valign="top"> 
        <td width="25%" bgcolor="#e5e5e5">$cnleft$</td>
        <td width="74%" bgcolor="#f3f3f3">$cnright$</td>
      </tr>
    </table>
    </body>
    </html>

    注意$cntop$、$cnleft$、$cnright$,它们将要实现某些具体的程序功能

    3,建立数据库连接文件conn.asp

    <%
    set conn= Server.CreateObject("ADODB.Connection")
    connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Server.MapPath("testmb.mdb")
    conn.Open connstr
    %>

    4,建立特殊字符串转换所需要的库文件lib.asp

    该文件的主要作用是将实现某些功能的ASP程序做成字程序,以方便调用。


    <%
    dim topcode
    sub cntop()
        topcode="现在时间是:"
        topcode=topcode&now()
    end sub

    dim leftcode,i
    sub cnleft()
        for i = 1 to 5
        leftcode=leftcode&"<p>cnbruce.com"
        next
    end sub

    dim rightcode
    sub cnright()
        for i = 1 to 9
        rightcode=rightcode&"<hr color="&i&i&i&i&i&i&">"
        next
    end sub 
    %>


    5,最后,调用数据库中的模板代码,将特殊字符串转换。


    <!--#include file="conn.asp" -->
    <!--#include file="lib.asp" -->
    <%
    sql="select * from moban where m_id=1"
    set rs=Server.CreateObject("adodb.recordset")
    rs.open sql,conn,1,1
    mb_code=rs("m_html")
    rs.close
    set rs=nothing

    cntop()
    mb_code=replace(mb_code,"$cntop$",topcode)
    cnleft()
    mb_code=replace(mb_code,"$cnleft$",leftcode)
    cnright()
    mb_code=replace(mb_code,"$cnright$",rightcode)

    response.write mb_code
    %>


    该页主要作用是将模板代码进行显示,并将其中的特殊代码转变为相对应子程序功能。

    至此,ASP的模板功能基本完成,剩下的就是:建立具备编辑模板功能的程序页面,将库文件改变为自己所需要程序功能……


    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=783511

    ASP.NET中应用模板采用

    1。用户界面

     using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using System.Data.SqlClient;
    using System.Text;
    namespace localhost.模版后台管理
    {
     /// <summary>
     /// UseInterface 的摘要说明。
     /// </summary>
     public class UseInterface : System.Web.UI.Page
     {
      protected string show_string;
      protected StringBuilder show_string2;
      private void Page_Load(object sender, System.EventArgs e)
      {
       // 在此处放置用户代码以初始化页面
       SqlConnection Conn;
       Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
       Conn.Open();   
       SqlDataAdapter da=new  SqlDataAdapter("select Skin_html from SkinBin where IsDefault=1",Conn);   
       DataSet ds=new DataSet();
       da.Fill(ds,"skin");
    //   show_string2.Append(ds.Tables["skin"].Rows[0][0].ToString());
    //   show_string2.Replace("$show_blogname$","无影杀手");//替换特殊标记
       show_string=ds.Tables["skin"].Rows[0][0].ToString();
       show_string=show_string.Replace("$show_blogname$","无影杀手");
       Response.Write(show_string);   
      }

      #region Web 窗体设计器生成的代码
      override protected void OnInit(EventArgs e)
      {
       //
       // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
       //
       InitializeComponent();
       base.OnInit(e);
      }
      
      /// <summary>
      /// 设计器支持所需的方法 - 不要使用代码编辑器修改
      /// 此方法的内容。
      /// </summary>
      private void InitializeComponent()
      {   
       this.Load += new System.EventHandler(this.Page_Load);
      }
      #endregion
     }
    }

    2。管理后台

    using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using System.Data.SqlClient;
    namespace localhost.模版后台管理
    {
     /// <summary>
     /// SkinManage 的摘要说明。
     /// </summary>
     public class SkinManage : System.Web.UI.Page
     {
      protected System.Web.UI.WebControls.DataGrid DataGrid2;
     
      private void Page_Load(object sender, System.EventArgs e)
      {
       // 在此处放置用户代码以初始化页面
       // 在此处放置用户代码以初始化页面
       SqlConnection Conn;
       Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
       Conn.Open();   
       SqlDataAdapter da=new SqlDataAdapter("select Id,Skin_name from SkinBin",Conn);
       DataSet ds=new DataSet();
       da.Fill(ds,"skin");
       da.Fill(ds,"skinall");
    //   show_string=ds.Tables["skin"].Rows[0][0].ToString();   
       DataGrid2.DataSource=ds.Tables["skinall"].DefaultView;
       DataGrid2.DataBind();
      }

      #region Web 窗体设计器生成的代码
      override protected void OnInit(EventArgs e)
      {
       //
       // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
       //
       InitializeComponent();
       base.OnInit(e);
      }
      
      /// <summary>
      /// 设计器支持所需的方法 - 不要使用代码编辑器修改
      /// 此方法的内容。
      /// </summary>
      private void InitializeComponent()
      {   
       this.DataGrid2.DeleteCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.DataGrid2_DeleteCommand);
       this.Load += new System.EventHandler(this.Page_Load);

      }
      #endregion

      private void DataGrid2_DeleteCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
      {
       try
       {
        SqlConnection Conn;
        Conn=new SqlConnection("server=localhost;database=Skin;uid=sa;pwd=''");
        Conn.Open();
        string Id="";
        Id=e.Item.Cells[2].Text;
        SqlCommand Comm=new SqlCommand("update SkinBin set IsDefault=1 where Id="+Id,Conn);
        Comm.ExecuteNonQuery();
       }
       catch
       {

       }
       Response.Write("<script>alert('模版已更改,请查看用户界面');</script>");

      }
     

      
     }
    }

    3。数据库

    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[SkinBin]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
    drop table [dbo].[SkinBin]
    GO

    CREATE TABLE [dbo].[SkinBin] (
     [Id] [int] IDENTITY (1, 1) NOT NULL ,
     [Skin_name] [char] (10) COLLATE Chinese_PRC_CI_AS NULL ,
     [Skin_html] [ntext] COLLATE Chinese_PRC_CI_AS NULL ,
     [IsDefault] [bit] NULL
    ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
    GO

    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=668003

  • 相关阅读:
    rac11.2.0.4私网公网修改
    OGG应用复制进程报错OGG 01161
    顺序容器vector拷贝使用总结
    C++迭代器(STL迭代器)
    C++容器(STL容器)
    win10桌面和手机的扩展API,判断是否有实体后退键API
    python Django 之 Model ORM inspectdb(数据库表反向生成)
    flask框架-大结局
    flask框架-下
    flask框架-中
  • 原文地址:https://www.cnblogs.com/zhangchenliang/p/681172.html
Copyright © 2011-2022 走看看