欢迎大家光临【无师自通-教程网】您的到来是我们的荣幸。本站提供photoshop教程,ps教程,flash教程,cad教程,网页制作教程,excel教程,asp教程,vb教程,3d教程,c语言教程,html教程,coreldraw教程,dreamweaver教程,java教程,3dmax教程 等各种教程为主题的内容和服务,相信您会在这里找到您所需要的东东。无师自通伴您一生-谢谢您的光临!!
网站地图 设为首页
简繁切换 加入收藏
栏目待定 留言本站
您现在的位置: 无师自通-教程网 >> WEB开发 >> ASP.NET教程 >> ASP.NET技巧 >> 教程正文

  没有公告

教程: ASP.NET教程-.NET技巧-开发基于Web的CSS设计器 更多...
教程: ASP.NET教程-.NET技巧-开发基于Web的CSS设计器

.quickviews.net/data/css/" target="_blank" class="keylink">CSSDesign>
<Category>
<Name>文字</Name>
<Style>
<Name>字体</Name>
......
</Style>
<Style>
<Name>样式</Name>
......
</Style>
......
</Category>
<Category>
<Name>背景</Name>
<Style>
<Name>颜色</Name>
......
</Style>
......
</Category>
</CSSDesign>

系统分为文字、背景、文本、位置、布局、方框、边框和其他,每种类型有一个Name子元素和若干Style子元素。


每个Style子元素表示一个Style属性,结构如下

<Style>
<Name>字体</Name>
<CssName>font-family</CssName>
<ActionType>select</ActionType>
<SelectItems>
<Item>verdana,arial</Item>
<Item Name="宋体">SimSun</Item>
<Item Name="黑体">SimHei</Item>
</SelectItems>
</Style>

<Style>
<Name>大小</Name>
<CssName>font-size</CssName>
<ActionType>select</ActionType>
<SelectItems>
<Item>12px</Item>
<Item>14px</Item>
<Item>9px</Item>
</SelectItems>
</Style>

<Style>
<Name>颜色</Name>
<CssName>background</CssName>
<ActionType>input_ColorSelect</ActionType>
</Style>


Name 为该属性的描述名称,在设计器中为文本描述;

CssName 为属性名,在设计器中即输入字段的ID,初始化时也据此赋值;

ActionType 为属性设置方法,在设计器中为输入字段的样式类名,该样式中含有Behavior属性,制定HTC组件;

SelectItems 为选择项,如果ActionType为Select,将会在此列出选择项;其子元素Item如果含有Name属性,将显示在设计器中,否则直接显示该元素的文本内容


框架图

此为缩略图,请点击打开

按此在新窗口打开图片
4.CSS设计器之界面交互

整个操作交互过程,除了最后保存文件外,其他都是由javascript完成。

首先DesignerBuild函数通过XmlDocumnet读取XML样式属性定义文件,构建整个设计器界面。然后Init函数读取服务器端赋给设计元素的Style.cssText属性,并把属性作为输入控件ID在设计器中查找并赋值,完成初始化。

在操作过程中,根据输入控件的样式类Class,触发绑定的HTC组件,做相应的客户端操作。

最后再读取设计元素的style属性,保存。


设计器界面
按此在新窗口打开图片
不同的设计元素
按此在新窗口打开图片
不同输入控件的不同class属性(根据XML中ActionType生成)触发不同HTC组件,实现不同输入模式。
按此在新窗口打开图片
按此在新窗口打开图片
按此在新窗口打开图片
由于商业原因,这里不便提供源代码;我将在后面提供部分关键代码供参考。


程序代码: 这里对前面文章讲的CSS设计器系统关键代码作一些小结,如果没有看过前面文章的请先参看"开发基于Web的CSS设计器"


解析CSS样式文件

这段代码主要作用是把CSS文件分解为多个样式类,并按名称/文本属性生成ClassItem对象,并保存在一个ArrayList(cssList)中(C#代码)

//读取文件
FileInfo theSource= new FileInfo (@m_filePath);
StreamReader reader = theSource.OpenText();
//将文件流转化为文本
m_cssText = reader.ReadToEnd();
reader.Close();
//定义CSS文本分割符
char[] delimiters = new char[] { '{','}'};
int iCheck = 1;
string className = null;
//将文本转化为ArrayList
foreach ( string substring in m_cssText.Split(delimiters))
{
if (iCheck%2==0)
//当iCHeck为偶数时,字符串为样式属性内容
//将解析的样式名和属性作为ClassItem对象存入cssList
cssList.Add( new ClassItem ( className, substring.Trim() ) );
else
//当iCHeck为奇数时,字符串为样式名,暂存
className = substring.Trim();
iCheck ;
}




交互界面构建

交互界面由Javascript通过XmlDocument读取Xml文件动态生成。

首先要读取XML文件,然后遍历整个XML文件,先遍历样式分类,再对每个分类遍历其下的所有样式属性。比较关键的代码是对XML的遍历,下面是对样式分类的遍历代码。


//LoadXML是XML文件读取函数
var dom = LoadXML("css.xml");
//通过XPath和selectNodes方法返回一个XMLDOMNodeList对象
var oNode = dom.selectNodes("//Category/Name");
//获取该对象长度,即XML文档中该路径节点的数量
var intCategory = oNodes.length;
for (i=0; i<intCategory; i )
{
//获取集合中的节点
oNode = oNodes.nextNode;
if (oNode != null)
{
//样式分类界面构建代码-略
……
}
}




样式输入控件构建函数,该函数作用是根据XPath路径查询XML定义,生成交互控件


function BuildInput ( path )
{
var str="";
var aNode=null;
var attValue=null;
//通过selectSingleNode返回符合条件的第一个节点
var actNode = dom.selectSingleNode(path "ActionType");
var nameNode = dom.selectSingleNode(path "CssName");
//如果属性为选择输入,则读取SelectItems,并构建select控件
if (actNode.text=="select")
{
str = "<select id='" nameNode.text "' name='" nameNode.text "' class='eSelect'>\n";

//查询该项的所有选择列表项
var itemsNodes = dom.selectNodes (path "SelectItems/Item");
str = "<option value='-1'>未设置</option>\n";
for (ii=0;ii<itemsNodes.length;ii )
{
aNode = dom.selectSingleNode (path "SelectItems/Item[" ii "]");

//如果该项含有Name属性则在列表中显示Name属性值
attValue = aNode.getAttribute("Name")
var txtNode = dom.selectSingleNode (path "SelectItems/Item[" ii "]");

if (attValue==null)
str = "<option value='" txtNod

上一页  [1] [2] [3] [4] 下一页

教程录入:admin    责任编辑:admin 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     
     
     
     

    asp连接mysql数据库

    asp连接mysql数据库-2

    frontpage2000教程---制作主页
    免责声明!本站资料大部分来自于互联网,其版权归原作者或其他合法者所有.如内容涉及或侵犯了您的权益,请通知本人,我将尽快处理!.欢迎您的光临。
    辽ICP备07003958号
    无师自通,伴你一生-教程网