在MVC中项目中使用JQuery,$.Post方法提交数据时产生中文乱码现象?
解决方法:
在$.post时进行数据编码,使用escape方法
$.post("@Url.Action("AddFriendLink" , "Setup")" ,{"Name" :escape(name)},function(data){
代码如下 | 复制代码 |
if(data>0){ alert( '添加成功!' ); window.location.reload(); } else{ alert( '添加失败!' ); } }); |
在后台进行解码,使用Server.UrlDecode方法。
代码如下 | 复制代码 |
public JsonResult Add(string Name) { DemoClass demoClass= newDemoClass { Name = Server.UrlDecode(Name) }; int result = demoService.Add(demoClass); return Json(result); } |
--------------------------------------------------------------------------------
2. MVC中如何设置文本框的宽度?
其实这个本不算是问题,不过刚开始还是写错了。
刚开始写的是:
代码如下 | 复制代码 |
@Html.TextBoxFor(model => model.Name, new { width="300px" }) (×) |
发现没有效果。
实施了第二方案,搞定了。
代码如下 | 复制代码 |
@Html.TextBoxFor(model => model.Name, new { @style = "width:300px" }) (√) |
--------------------------------------------------------------------------------
3.Html.RadioButtonFor怎么使用呢?
像下面这样就可以了。当Model.IsStudent=true时会自动选中第一项,以此类推。
代码如下 | 复制代码 |
@Html.RadioButtonFor(model=>model.IsStudent,true)是 @Html.RadioButtonFor(model => model.IsStudent, false)否 |
--------------------------------------------------------------------------------
4. @helper自定义方法
代码如下 | 复制代码 |
@helper GetStatusName(int status) { //code block } |
调用时直接使用@GetStatusName(2)即可。
--------------------------------------------------------------------------------
5.model多级引用时,对应的html?
代码如下 | 复制代码 |
@ Html.TextBoxFor(model => model.Topic.Title) |
对应生成的HMTL代码为:
代码如下 | 复制代码 |
在写脚本的时候要注意了啊。
--------------------------------------------------------------------------------
6.DropDowlList控件数据绑定的几种常用方式?
①下拉框中的选项为几个简单的固定值。
代码如下 | 复制代码 |
@Html.DropDownList("ProvinceId", new SelectListItem[]{ new SelectListItem{ Text="选择类别",Value="0", Selected=true}, new SelectListItem{Text="类别A",Value="1"}, new SelectListItem{Text="类别B",Value="2"} }) |
②将数据封装为SelectList类型,并且放在ViewBag中进行传递。
controller层:
代码如下 | 复制代码 |
IList< Person> personList =personService.GetList(); ViewBag.personId= new SelectList(personList , "Id", "Name", queryParam.EditorId); |
View层:直接根据ID进行绑定就可以了。
@Html.DropDownList( "personId")
③如果页面中的数据比较多,直接都放在viewbag中传递会比较乱,我们可以将页面中需要的数据封装成一个类,其中Select类型被封装为一个属性。
封装类
代码如下 | 复制代码 |
public class IndexView { public SelectList PersonList{get;set;} … } controller: 对IndexView中的属性赋初始值。 IndexView indexView = new IndexView () { PersonList= new SelectList(personList , "Id", "Name", personList ) }; ViewBag.indexView = indexView; View: |
--------------------------------------------------------------------------------
7.异步提交表单时,要记得Ajax.BeginForm哟!
做表单提交时,绕的小弯子:
刚开始想用@Html.BeginForm()+MVC3验证来实现,可是想异步提示结果啊。
用Jquery中的.post方法提交,那就得把验证加在客户端脚本了。
后来突然想起了老被我遗忘了的Ajax.BeginForm()方法。实现了我的需求。(*^__^*) 嘻嘻……
代码如下 | 复制代码 |
@ using (Ajax.BeginForm( "Index", "Manage" , new AjaxOptions { HttpMethod = "Post", OnSuccess = "Success", OnFailure = "Failure" })) { @Html.ValidationSummary(true) @ Html.TextBoxFor(model => model.Name, new { @style = "width:300px" }) @Html.ValidationMessageFor(model => model.Name) } ////脚本提示执行结果 function Success() { alert( "修改成功" ); } function Failure() { alert( "修改失败!" ); } |
其中还可以设置 UpdateTargetId属性,执行结果后用来显示执行结果。
重要的一点是要添加
代码如下 | 复制代码 |
现在基本成功了。
疑问:
还有最后一个问题是产生了中文乱码现象?用Html.BeginForm没问题,用Ajax.BeginForm就会出现乱码。(博问地址)
最后终于找到原因了:
view里面和web.config里的编码有冲突了:
代码如下 | 复制代码 |
web.config: |
还希望各位大牛能够慷慨的提供一种比较好的解决方案,这里是测试项目
在这里我总结我所了解的mvc开发中的碰到的常见问题了,如果大家有更多资料可在下面评论提供。