asp.net mvc后台操作之读写xml控制首页动态页面开关显示
一、背景
在asp.net mvc项目里,用户需要开拓几个活动版面,并以侧栏的方式呈现在首页右侧,几个活动时间不一致,为避免浏览者在活动未开放之时进入未开放的服务页面。因此不仅需要在活动代码中加入限制功能,也需要在前台取消不合时宜的页面的展示。后台效果图:

二、问题分析
要想控制页面开关显示,就得有存储开关信息的介质,将在后台产生的操作记录下来,并在浏览者加载首页之时能读取操作记录并达到控制页面开关的目的。因此,考虑两种介质储存开关记录信息,一是用数据库mysql,二是用xml。考虑到这对数据库的功能大材小用,并且会增加首页加载时对数据库资源消耗,所以考虑使用xml文档来记录开关记录才是两者中较好的选择。这里需要我们做一下前期工作,先设计xml的结构:
<?xml version="1.0" encoding="gb2312"?>
<Settings>
<Setting ID="1">
<title>****</title>
<status>true</status>
</Setting>
</Settings>
说明的是:ID是对应多个纪录的setting区分标记,title是设置页面的名字,也就是服务的名字,status表明当前的服务页面的状态,有两个值:true or false。在项目里添加名为Xml的文件夹,并保存设计的XML的命名为ServiceSettings.xml。
三、解决思路或过程
首先,产生开关操作需要页面上的控件,这里使用的checkbox标签,当然这不是唯一选择,朋友们可以用其他的标签来作为输入控件的使用。思路是:我触击checkbox,对应的js代码记录值,并以ajax上传至后台action中,后台的action作出反应。
js代码:
function BloodController() {
$.ajax({
type: "POST",
url: "/Admin/Controller",
data: {},
dataType: "Json"
});
}
html代码:
<input name="switch-field-1" class="ace ace-switch ace-switch-6" type="checkbox" onclick="Controller()" />
ajax中的data,在这里不标出。触发后台action一次,那么就会运行action中操作xml的代码,那么就会改变xml中记录的值。
然后,是action中操作xml的实现。思路是:首先要获取xml在应用程序中的相对位置,然后便是更改xml的值。
public string Xmlpath = HttpRuntime.AppDomainAppPath.ToString() + "/Xml/ServiceSettings.xml";
public ActionResult Controller()
{
OperateXml sx = new OperateXml();
sx.modifyXml(Xmlpath);
return Json("");
}
说明的是:HttpRuntime.AppDomainAppPath.ToString();方法可以获取当前应用程序所在的根目录。为了操作多个xml文件,我写了OperateXml一个类方法,这里进入对xml的操作细节介绍。
对于xml操作的原理不多说,其实ado.net支持的也很棒,xml文档的结构类似于html,但它的自由度更高,可标记性也更高。不多说,直接上代码,注释里都解释了:
public void modifyXml(string Path)
{
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(Path);
XmlNodeList nodeList = xmlDoc.SelectSingleNode("Settings").ChildNodes;//获取bookstore节点的所有子节点
foreach (XmlNode xn in nodeList)//遍历所有子节点
{
XmlElement xe = (XmlElement)xn;//将子节点类型转换为XmlElement类型
")
{
XmlNodeList nls = xe.ChildNodes;//继续获取xe子节点的所有子节点
foreach (XmlNode xn1 in nls)//遍历
{
XmlElement xe2 = (XmlElement)xn1;//转换类型
if (xe2.Name == "status")//如果找到
{
if (xe2.InnerText != "false")
{
xe2.InnerText = "false";//则修改
break;//找到退出来就可以了
}
else if (xe2.InnerText == "false")
{
xe2.InnerText = "true";//则修改
break;//找到退出来就可以了
}
}
}
break;
}
}
xmlDoc.Save(Path);//保存。
}
因为代码注释里解释得够清晰了,这里不做赘述,需要说明一点是:这里的status只有两个值:true or false;在前台读出的便是这两个值,来进行页面控制的。
接着,就是前台的读取xml里的值。思路是:在动态页面里读取xml值,然后做判断,true则显示页面,false则不显示页面。这里读xml代码贴出,注释里解释详细了。需要说明的是:这里为了控制多个页面的显示,用了List<string>来转载多个status的值。
public List<string> getAllXml(string Path)
{
string status = "";
XmlDocument doc = new XmlDocument();
doc.Load(Path);
XmlNode xn = doc.SelectSingleNode("Settings");
XmlNodeList xnl = null;
xnl = xn.SelectNodes("/Settings/Setting/status");
List<string> list = new List<string>();
foreach (XmlNode xn1 in xnl)
{
status = xn1.InnerText;
list.Add(status);
}
return list;
}
需要说明的是:这里为了控制多个页面的显示,用了List<string>来转载多个status的值。在前台页面里页面里就这样实现:
@using TheOne.Tool
@{
OperateXml sx = new OperateXml();
List<string> list = new List<string>();
string path = HttpRuntime.AppDomainAppPath.ToString() + "/Xml/QuickServiceSettings.xml";
list = sx.getAllXml(path);
].ToString();
//string status_Bottle = list[1].ToString();
//string status_Older = list[2].ToString();
//string status_Blood = list[3].ToString();
}
@if (status_Umbrella == "true")
{
<div class="blog-grids wow fadeInDown" data-wow-duration=".8s" data-wow-delay=".2s">
<div class="blog-grid-left">
<a href="/UmbrellaManage/CreateUmbrellaUser"><img src="/Content/FrontEnd/images/yusan_2.jpg" class="img-responsive" alt=""></a>
</div>
<div class="blog-grid-right">
<h5><a href="/UmbrellaManage/CreateUmbrellaUser">借用雨伞</a> </h5>
</div>
<div class="clearfix"> </div>
</div>
}
else if (status_Umbrella == "false")
{
}
到这里,使用xml控制页面开关介绍基本结束。
四、总结
思路中最核心的便是对xml的操作,修改xml和读取xml。而对于如何实现checkbox状态切换,这个实现可以使用js来操作,读出status值,并让相应的js代码控制checkbox的状态是选中还是未选中。实际项目演示地址:点击 南农工红会
如果我思路和方法有误,恳请各位指正,虚心求教。转载请注明来源与出处,谢谢合作 By 点将台无将
asp.net mvc后台操作之读写xml控制首页动态页面开关显示的更多相关文章
- ASP.NET MVC 后台接收集合参数和 jquery ajax 传值
MVC 接收参数数组(集合) 示例样本: public class Person { public string FirstName { get; set; } publi ...
- 序列化json对象,通过ajax传入asp.net mvc后台
序列化json对象,通过ajax传入asp.net mvc后台 序列化json对象,通过ajax传入asp.net mvc后台 今天遇到一个问题,准备把组织好的json对象通过jquery.aja ...
- ADO.NET .net core2.0添加json文件并转化成类注入控制器使用 简单了解 iTextSharp实现HTML to PDF ASP.NET MVC 中 Autofac依赖注入DI 控制反转IOC 了解一下 C# AutoMapper 了解一下
ADO.NET 一.ADO.NET概要 ADO.NET是.NET框架中的重要组件,主要用于完成C#应用程序访问数据库 二.ADO.NET的组成 ①System.Data → DataTable, ...
- 在ASP.NET MVC 3 中自定义AuthorizeAttribute时需要注意的页面缓存问题
一.ASP.NET MVC中使用OutputCache实现服务器端页面级缓存 在ASP.NET MVC中,假如我们想要将某个页面(即某个Action)缓存在服务器端,可以在Action上标上以下特性: ...
- ASP.NET MVC 表格操作
Beginners Guide for Creating GridView in ASP.NET MVC 5 http://www.codeproject.com/Articles/1114208/B ...
- 尝试asp.net mvc 基于controller action 方式权限控制方案可行性
微软在推出mvc框架不久,短短几年里,版本更新之快,真是大快人心,微软在这种优秀的框架上做了大量的精力投入,是值得赞同的,毕竟程序员驾驭在这种框架上,能够强力的精化代码,代码层次也更加优雅,扩展较为方 ...
- 尝试asp.net mvc 基于controller action 方式权限控制方案可行性(转载)
微软在推出mvc框架不久,短短几年里,版本更新之快,真是大快人心,微软在这种优秀的框架上做了大量的精力投入,是值得赞同的,毕竟程序员驾驭在这种框架上,能够强力的精化代码,代码层次也更加优雅,扩展较为方 ...
- ASP.NET MVC扩展自定义视图引擎支持多模板&动态换肤skins机制
ASP.NET mvc的razor视图引擎是一个非常好的.NET MVC框架内置的视图引擎.一般情况我们使用.NET MVC框架为我们提供的这个Razor视图引擎就足够了.但是有时我们想在我们的项目支 ...
- ASP.NET MVC 扩展自定义视图引擎支持多模板&动态换肤skins机制
ASP.NET mvc的razor视图引擎是一个非常好的.NET MVC 框架内置的视图引擎.一般情况我们使用.NET MVC框架为我们提供的这个Razor视图引擎就足够了.但是有时我们想在我们的 ...
随机推荐
- iOS中的交换空间(swap space)
看来是没有交换空间,原因是闪存和SSD硬盘相比,速度很慢,也有电源管理的原因. the NAND flash is not designed to be used as swap. It is dam ...
- js获取网页高度
网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网页可见区域宽: document.body.offsetWi ...
- width 、 height 与 box-sizing : border-box ,content-box 的关系
默认 width .height的 content-box 的宽高. box-sizing 经常用来设置 width.height指定的区域 box-sizing 经常用做一些自适应的布局. 语法: ...
- T-SQL查看数据库恢复(RESTORE)时间
WITH LastRestores AS ( SELECT DatabaseName = [d].[name] , [d].[create_date] , [d].[compatibility_lev ...
- jstorm集群部署
jstorm集群部署下载 Install JStorm Take jstorm-0.9.6.zip as an example unzip jstorm-0.9.6.1.zip vi ~/.bashr ...
- MySQL有关Group By的优化
昨天我写了有关MySQL的loose index scan的相关博文(http://www.cnblogs.com/wingsless/p/5037625.html),后来我发现上次提到的那个优化方法 ...
- PostgreSQL-PL/pgSQL
参考: https://wiki.postgresql.org/wiki/9.1%E7%AC%AC%E4%B8%89%E5%8D%81%E4%B9%9D%E7%AB%A0 摘记: PL/pgSQL是 ...
- 【转】Java并发编程:Lock
阅读目录 一.synchronized的缺陷 二.java.util.concurrent.locks包下常用的类 三.锁的相关概念介绍 来自: http://www.importnew.com/18 ...
- 在macOS Sierra 10.12搭建PHP开发环境
macOS Sierra 11.12 已经帮我们预装了 Ruby.PHP(5.6).Perl.Python 等常用的脚本语言,以及 Apache HTTP 服务器.由于 nginx 既能作为 HTTP ...
- ipv4理论知识3-分类编址之两级编址
两级编制 分类编址时,同一网络中的所有地址都属于统一个地址块,而每个地址块包含两部分:网络标识和主机标识.网络标识指明了网络,主机标识则指明了连接到该网络的一台特定的主机.如下图描绘了分类编址中一个I ...