.Net 学习笔记

我的学习笔记

博客园 首页 新随笔 联系 订阅 管理
  6 Posts :: 1 Stories :: 6 Comments :: 0 Trackbacks

2006年12月30日 #

原文连接:http://www.w3cn.org/article/layout/2004/88.html

如何使整个页面内容居中,如何使高度适应内容自动伸缩。这是学习CSS布局最常见的问题。下面就给出一个实际的例子,并详细解释。(本文的经验和是蓝色理想论坛xpoint、guoshuang共同讨论得出的。)

首先先按这里看实际运行效果,这个页面在mozilla、opera和IE浏览器中均可以实现居中和高度自适应。我们来分析代码:

<html>
<head>
<style type="text/css">
body
{
background
:#999;
text-align
:center;
color
: #333;
font-family
:arial,verdana,sans-serif;
}
#header
{
width
:776px;
margin-right
: auto;
margin-left
: auto;
padding
: 0px;
background
: #EEE;
height
:60px;
text-align
:left;
} #contain{
margin-right
: auto;
margin-left
: auto;
width
: 776px;
} #mainbg{
width
:776px;
padding
: 0px;
background
: #60A179;
float
: left;
}
#right
{
float
: right;
margin
: 2px 0px 2px 0px;
padding
:0px;
width
: 574px;
background
: #ccd2de;
text-align
:left;
}
#left
{
float
: left;
margin
: 2px 2px 0px 0px;
padding
: 0px;
background
: #F2F3F7;
width
: 200px;
text-align
:left;
}
#footer
{
clear
:both;
width
:776px;
margin-right
: auto;
margin-left
: auto;
padding
: 0px;
background
: #EEE;
height
:60px;}
.text
{margin:0px;padding:20px;}
</style>
</head>
<body>
<div id="header">header</div>
<div id="contain">
<div id="mainbg">
<div id="right">
<div
class="text">right<p>1</p><p>1</p><p>1</p><p>1</p><p>1</p></div>
</div>
<div id="left">
<div class="text">left</div>
</div>
</div>
</div>
<div id="footer">footer</div>
</body>
</html>



首先我们定义body和顶部第一行#header,这里面的关键是body中的text-align:center;和header中的margin-right: auto;margin-left: auto;,通过这两句使得header居中。注:其实定义text-align:center;就已经在IE中实现居中,但在mozilla中无效,需要设置margin:auto;才可以实现mozilla中的居中。

接下来定义中间的两列#right和#left。为了使中间两列也居中,我们在它们外面嵌套一个层#contain,并对contain设置margin:auto;,这样#right和#left就自然居中了。

注意中间两列定义的顺序,我们首先定义#right,通过float: right;让它浮在#contain层的最右边。然后再定义#left,通过float: left;让它浮动在#right层的左面。这和我们以前表格从左到右定义的顺序正好相反(更正:先左后右、还是先右后左都可以实现,根据自己需要设计)。

我们看到代码中在#contain和两列之间还嵌套了一个层#mainbg,这个层是做什么用的呢?这个层就是用来定义#contain的背景的。 你肯定会问,为什么不直接在#contain中定义背景,而要多套一层呢?那是因为在#contain中直接定义的背景,在mozilla中将显示不出 来,必须定义高度值才可以。如果定义了高度值,#right层就无法实现根据内容的自动伸缩。为了解决背景和高度问题,就必须增加这么一个#mainbg 层。窍门在于#mainbh这个层定义float: left;,因为float使层自动有宽和高的属性。(暂且这么理解:)

最后是定义底部的#footer层。这个定义的关键是:clear:both;,这一句话的作用是取消#footer层的浮动继承。否则的话,你会看到#footer紧贴着#header显示,而不是在#right的下面。

主要的层定义完毕,这个布局就ok了。补充一点:你看到我还定义了一个.text{margin:0px;padding:20px;}, 这个class的作用是使内容的外围有20px的空白。为什么不直接在#right里定义margin或者padding呢,因为mozilla和IE对 css盒模型的解释不一致,直接定义margin/padding会造成mozilla里布局变形。我一般采用内部再套一层的做法来解决。



posted @ 2006-12-30 21:13 AntiGameZ 阅读(64) | 评论 (0)编辑

     摘要: 也许是之前被DropDownList折磨惨了,这两天时不时的都要研究下这个小玩意,今天写SiteMap的时候想起来DDL能和XMLDataSource绑定,不知道折腾起来怎么样。当然,DDL也可以直接和SiteMapDateSource进行绑定,但是我就不采用这个方法了。XML文件,太长,折叠了一下,展开察看:Code highlighting produced by Actipro CodeHi... 阅读全文
posted @ 2006-12-30 00:16 AntiGameZ 阅读(371) | 评论 (3)编辑

看了很多人都是自己程序获得用户的角色权限,再判断并编写相应的功能菜单,其实.net 中可以允许开发者自己拼合这些功能;
废话不说,网上也有很多这样的资料,但我感觉说教太多,自己来简单归纳一下方便给大家!

注:站点必须为asp.net 标准验证方式。自定义cookie认证,自定义Session方式的可以一边凉快去了!

具体条件
   1、为站点准备SiteMap
      在站点根目录建立一个Web.sitemap 配置文件,例:

 1 <?xml version="1.0" encoding="utf-8" ?>
 2 <siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
 3     <siteMapNode url="~/Default.aspx" title="首页"  description="" >
 4         <siteMapNode url="~/Register.aspx" title="注册"  description="" />
 5         <siteMapNode url="~/Login.aspx" title="登陆"  description="" />
 6       <siteMapNode url="~/Album/Default.aspx" title="个人管理" description="">
 7         <siteMapNode url="~/Album/AlbumManager.aspx" title="相册管理" description="" />
 8         <siteMapNode url="~/Album/ImageUploader.aspx" title="图片上传" description="" />
 9         <siteMapNode url="~/Album/ImageManager.aspx" title="图片管理" description="" />
10       </siteMapNode>
11     </siteMapNode>
12 </siteMap>

注意:第一级节点只能有1个,其他节点就随意了,可以把全站所有有关的页都编写进来,也可以只写有权限      控制相关的页,这个是可以继承的。
   安装有MSDN2005的朋友可以看此内容:ASP.NET 站点地图
      ms-help://MS.VSCC.v80/MS.MSDN.v80/MS.VisualStudio.v80.chs/dv_aspnetcon/html/6b85a558-1df8-44cf-bea6-62e61bcc8d20.htm
  
   2、为文件或目录设置访问权限
      在相关目录的Web.config 中设置就可以,跟平时设置一样

 1 <system.web>
 2       <authorization>
 3         <!-- 当前目录由Album 角色的用户才可以访问 -->
 4         <allow roles="Album" />
 5         <deny users ="*"/>
 6       </authorization>
 7     </system.web>
 8   
 9   <location path="ImageUploader.aspx">
10     <system.web>
11       <authorization>
12         <!-- ImageUploader.aspx 只能带Blog角色的用户才可以访问 -->
13         <allow roles="Blog"/>
14         <deny users ="*"/>
15       </authorization>
16     </system.web>
17   </location>


   3、在根Web.config 中启用站点地图角色过滤配置,想省事可以直接复制粘贴
 1   <system.web>
 2     <siteMap defaultProvider="XmlSiteMapProvider" enabled="true">
 3       <providers>
 4         <add name="XmlSiteMapProvider"
 5           description="Default SiteMap provider."
 6           type="System.Web.XmlSiteMapProvider "
 7           siteMapFile="Web.sitemap"
 8           securityTrimmingEnabled="true" />
 9       </providers>
10     </siteMap>
11   </system.web>
12 


就这样就OK了!测试一把~~!

   1、拖一个Menu 控件到页面上,并新建一个数据源类型为“站点地图”类型,名字随意。点OK就配置好了!

    测试用例1:(没有登陆以前,只显示根目录下谁都可以访问的文件)
    
   测试用例2:(登陆后,具备Album 角色但不具备Blog 角色能力)
   
   测试用例3:(登陆后,具备Album角色也具备Blog 角色)
   

完成收工,回家了,显然这样的方式,大量减少的代码,而且把页面文件或目录跟角色绑定起来,实在是非常方便的。
posted @ 2006-12-30 00:03 AntiGameZ 阅读(87) | 评论 (1)编辑