TodoList开发笔记 – Part Ⅲ

本节开始对TodoList项目的客户端进行开发

一.初步了解JQuery

其实我在学校时有接触过一段时间的Web开发,虽然代码量不多也不复杂,但也已经感受到了各浏览器对Web各项标准的恶意,Web界对当时的我来讲,就是贵圈太乱,一个标准出来得磨掉好多事,特别是JavaScript这种极其灵活的语言,到不同人不同浏览器手里差别太大了。

这几年不一样了,互联网火了,技术也推进了,首当其冲就是JQuery的出现,解放你我他啊。

简单来说JQuery就是一个类库,提供各种便捷的方法操作DOM、Javascript对象等等等。而且它能极大的保证各浏览器下的兼容性,只要是通过JQuery对象调用的方法,那么差异性基本是没有的。程序员是这么一群生物,解决问题大多数时候都是引入一个间接层。

类库相比框架,对代码的限制就少很多,这么多年下来JQuery也证明了它是经得起考验的,现在MVC项目默认都引用了它。

二.初步了解Bootstrap

其实我发觉Web的发展越来越跟桌面软件有点像了,也开始出现各种UIToolkit,Bootstrap就是其中的佼佼者了,也是经过考验后被加入MVC默认项目里了。

Bootstrap拥有不少美观的UI组件,从按钮、工具提示、输入组到模式窗口Modal应有尽有,CSS样式也写得简单易懂,非常方便修改。

三.界面设计

说了这么多可以开始扯界面了,下面是我仿造后的效果图,好像字体大了点

下面是CSHTML代码(Razor视图文件)


@{
Layout = null;
}

<head>
<title>TodoList</title>

<script>
// window.resizeTo(300, 600);
</script>
@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/bootstrap")

<script src="../../Scripts/bootstrap-select.js"></script>
<script src="../../Scripts/jquery.form.js"></script>
<script src="../../Scripts/Views/Index.js"></script>
<link rel="stylesheet" type="text/css" href="../../Content/bootstrap.css" />
<link rel="stylesheet" type="text/css" href="../../Content/bootstrap-select.css" />
<link rel="stylesheet" type="text/css" href="../../Content/Views/Index.css" />
</head>

<body>
@{
var catalogs = ViewBag._todoCatalog;
foreach (var catalog in catalogs)
{
<div class="div_catalog">
<!--归类名称-->
<div data-catalogid="@catalog.CatalogId" class="div_catalogName">
@catalog.CatalogName
<button class="btn_Add"></button>
@{
var count = catalog.Events.Count;
<!--归类下事项总数-->
<strong class="strong_eventCount">
(@count)
</strong>
}
</div>

@foreach (TodoEvent todo in catalog.Events.Values)
{
<div class="div_todoevent">
<div class="div_todoSummary">
<button class="btn_Completed"></button>
@if (todo.Completed)
{
<button class="btn_DeleteEvent"></button>
}

<div data-eventid="@todo.EventId"
data-catalogid="@todo.CatalogId"
data-remark="@todo.Remark"
data-index="@todo.Index"
data-remindtime="@todo.RemindTime"
data-createdatetime="@todo.CreateDateTime"
data-summary="@todo.Summary"
data-location="@todo.Location"
data-completed="@(todo.Completed ? "true" : "false")"
class="@(todo.Completed ? "div_CompletedSummary" : "div_DefaultSummary")">
@todo.Summary
</div>
</div>
</div>
}
</div>
}

<input type="text" id="NewCatalog" class="input_Catalog" placeholder="NewCatalog..." />
}
</body>

<!-- 代办事项编辑窗口,平时隐藏 -->
<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog">
<form id="form_TodoEvent" method="post">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
<h4 class="modal-title" id="myModalLabel">想做点什么......</h4>
</div>

<div class="modal-body">
<input id="eventid" name="eventid" type="text" style="visibility:hidden;" />
<input id="catalogid" name="catalogid" type="text" style="visibility:hidden;" />

<div class="input-group">
<span class="input-group-addon">主题</span>
<input id="summary" name="summary" type="text" class="form-control" placeholder="做点什么......">
<a href="#" id="tip_Summary" style="visibility:hidden;float:right;margin-top:-20px" rel="popover" data-content="不知道干嘛?" ></a>
</div>
<br />

<div class="input-group">
<span class="input-group-addon">地点</span>
<input id="location" name="location" type="text" class="form-control" placeholder="在哪里......">
</div>
<br />

<div class="input-group">
<span class="input-group-addon">备注</span>
<input id="remark" name="remark" type="text" class="form-control" placeholder="别忘了......">
</div>
<br />

</div>
<br />

<div class="modal-footer">
<button id="btn_CancelEdit" type="button" class="btn btn-default" data-dismiss="modal">算了吧</button>
<button id="btn_SaveEvent" type="button" class="btn btn-primary">帮我记住吧</button>
</div>
</div>
</form>
</div>
</div>

这里大量采用了HTML5新增的属性
data-AttributeName,因为模型数据要绑定在HTML元素上,实在想不到有比这个更简单的方式了。

四.脚本编写

因为是单页应用所以脚本比较集中,大部分是提交请求接收结果然后更新界面元素,我只贴两个关键的代码

第一个是JQuery提交表单


var form = $(‘#form_TodoEvent‘);
$.ajax({
url: ‘/TodoList/SaveEvent‘,
cache: false,
async: true,
type: "POST",
data: form.serialize(),
error: function (message) { alert(message); },
success: function (result) { EventSaved(result); }
});

第二个是JQuery提交Json数据


//更新代办事项是否已完成
$.ajax({
url: ‘/TodoList/UpdateCompleted‘,
async: true,
type: "POST",
data: { "eventId": eventid, "completed": completed },
success: function (result) { }
});

这样就完成了客户端与服务端的交互,后台的代码其实很简单,就是定义一系列Action去接收Ajax提交的数据,然后就爱干嘛干嘛啦。

注意result是我定义的一个消息实体,用来传递数据的。

其它的脚本大部分都是些更改界面的代码,大部分都很繁琐,真不敢想象没有JQuery自己手动写这些会有多痛苦。

时间: 2024-08-10 23:28:47

TodoList开发笔记 – Part Ⅲ的相关文章

TodoList开发笔记 – Part Ⅱ

上一节给出了应用的两个主要UML类图,应用采用的技术也给出了,这一节开始实际设计编码 一.应用公开的方法 其实就几个的方法而已 1.代办事项的CRUD 2.代办事项归类目录的CRUD 3.代表事项"已完成"的更改. 二.MVC如何应用到系统中 引入MVC框架是为了更好的抽象应用程序各个模块,强制将应用程序分为三个大部分(Model-View-Controller),那么我们的应用在MVC框架下各个模块是怎么存放的呢? Model: TodoCatalog.TodoEvent View:

TodoList开发笔记 – Part Ⅳ

跌跌撞撞总算是把客户端开发好了,后台的代码因为不复杂,就写了些单元测试跑一跑就算通过了,大部分时间都是在调整脚本. 这一节开始部署TodoList项目. 一.了解IIS(Internet Infomation Service) 一个Http请求从浏览器发送到服务器接收,其实是经过相当多的步骤的,我们不说客户端的,就单单服务器这边. 1.首先Http是基于Tcp协议的,那么作为服务器我们就得一直监听指定的端口去接收客户端连接,这件事由tcpip.sys内核驱动去帮我们完成. 2.连接完后捏从Tcp

TodoList开发笔记 – PartⅠ

做了一年多的桌面软件,最近开始转向Web方面的开发,既然比较熟悉Net那么首当其冲就是学习ASP.Net,以及HTML.CSS.Javascript. 为了检验这个把星期来的学习成果,着手做了一个TodoList的小应用,记录于此. 一.这个应用解决什么 只是作为Any.Do的仿制品而已...练练手 二.这个应用如何搭建而成 服务器主框架: ASP.Net MVC 数据访问: Linq To Sql 客户端开发: HTML.CSS.Javascript 用到的组件: JQuery.Bootstr

张高兴的 Windows 10 IoT 开发笔记:RTC 时钟模块 DS3231

原文:张高兴的 Windows 10 IoT 开发笔记:RTC 时钟模块 DS3231 GitHub:https://github.com/ZhangGaoxing/windows-iot-demo/tree/master/DS3231 注意:不包含闹钟设置

Android开发笔记(一百零三)地图与定位SDK

集成地图SDK 国内常用的地图SDK就是百度和高德了,二者的用法大同小异,可按照官网上的开发指南一步步来.下面是我在集成地图SDK时遇到的问题说明: 1.点击基本地图功能选项,不能打开地图,弹出"key验证出错!请在AndroidManifest.xml文件中检查key设置的"的红色字提示.查看日志提示"galaxy lib host missing meta-data,make sure you know the right way to integrate galaxy&

微信订阅号开发笔记(二)

微信开发的流程其实很简单 o(∩_∩)o 哈哈!在微信网站的编辑操作 额,就不说了.虽然有人问过.下面是我的微信开发过程,简单记录下. 成为开发者 材料:1.自己的服务器资源,百度的BAE,新浪的SAE都不错. 2.懂那么点编程语言. 3.注册微信公众号. 上面的都有了之后,就可以自己动手开发了.哇咔咔,好兴奋.有木有. 在登录进去之后,怎么成为开发者?不知道,自己看去. 开始coding吧. 1.验证 if (! empty ( $_GET ['echostr'] ) && ! empt

微信订阅号开发笔记(三)

1.接收语音识别结果 if($msgType=="voice"){ //收到语音消息 //MediaId 语音消息媒体id,可以调用多媒体文件下载接口拉取数据. //Format 语音格式,如amr,speex等 $format = $postObj->Format; $mediaId = $postObj->MediaId; //开通语音识别功能,用户每次发送语音给公众号时,微信会在推送的语音消息XML数据包中,增加一个Recongnition字段. //注:由于客户端缓

微信订阅号开发笔记(四)

1.创建菜单 //创建菜单 public function createMenu(){ $url = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token="; $url.=$this->getacctoken(); //目前自定义菜单最多包括3个一级菜单,每个一级菜单最多包含5个二级菜单.一级菜单最多4个汉字, //二级菜单最多7个汉字,多出来的部分将会以"..."代替.请注意,创建自定义菜单

Swift开发笔记

Swift开发笔记(一) 刚开始接触XCode时,整个操作逻辑与Android Studio.Visual Studio等是完全不同的,因此本文围绕IOS中控件的设置.事件的注册来简单的了解IOS开发 1.新建一个Xcode项目,项目目录大致如图: 2.在Main.storyboard添加控件 首先要显示右侧的工具栏(Utilities),之后选择显示Object Library,就可以找到常用的一些控件了,然后添加几个控件到界面中 3.将控件和ViewController进行关联 此时要将Ed