【ASP.NET MVC】数据到客户端(7)

前文ViewBag数据在服务端动态生成页面,也可以传到客户端浏览器供JS使用。

一、数据从控制器到客户端

前文介绍,动态生成页面时,控制器的数据 并没有传递到 客户端,而是给自己来用,生成View 再利用http传递到客户端浏览器。

当然数据也是可以传递给客户端的,但有需要先搞明白传递到客户端的 数据 给谁用?谁能够使用这些数据? 答案很简单: JS   (JavaScript ) ,其他的JQuery 等可以视为对JS的包装,也可以在客户端 “动起来” 

传递方法:

1、直接用 HTML 的元素的 属性来进行数据来传递(样式设置为 style="display:none" ,不显示该元素)

参考代码:

页面

<input id="test" style="display:none" value='@ViewBag.data'/>
<script>
    window.onload = function () {
      
        alert(document.getElementById("test").value);
    }
</script>

控制器里添加:

  ViewBag.data = "Just test!";

思路比较简单,服务器生成页面的时候 取 ViewBag 数据,并将数据赋值给id 为test 的 input 元素的 属性value ,传递到客户端后,JS转载,在页面加载完成后 ( window.onload ),自动执行代码 alert(document.getElementById("test").value);  

2、直接在JS代码中传数据

比第一种方法更简单的是在JS代码中值贴数据,JS代码也是控制器生成的! 代码如下:

<script>
    var msg = '@ViewBag.data';
    window.onload = function () {
      
        alert(msg);
    }
</script>

要理解,var msg = '@ViewBag.data';  这行也是在服务端生成的!所ViewBag可以使用。

var msg = @ViewBag.data; 语法错误,记得带(单双)引号。

二、数据类型

以上可以解决数据传递到浏览器,但是数据类型也是需要解决的问题——数据类型肯定不限于简单的值类型,肯定还有其它复合数据类型,比如集合类型?组合类型?

例:Echarts用来绘制图形的数据就很可能是一系列的数据(X轴,Y轴),对应就是集合类型的数据。

服务器与客户端数据传递数据,目前而言,比较通用的是JSON——搞明白它的用途,理解JSON就并不难了

JSON就是用一种指定 方式来让数据保持它原有的类型信息。网络传输使用的是字节流:什么面向对象、集合类型、甚至是普通的整数、浮点数都没有!就是一堆字节(八位二进制),那么肯定需要一种方法来对数据进行“补充”说明,以此来解释传送过来的一堆字节流!

JSON补充一些符号,比如双引号(“”),括号(中括号、大括号)、逗号等,通过嵌套组合来描述数据之间的关系。

其实最主要的就两种结构: 集合与组合,值得注意的是它们两可以相互嵌套,如:传送一个学生集合,学生又包括了姓名、年龄等(组合类型),而且学生还包括选修的课程列表,组合的学生类型里又包括了一个选修课的集合类型!

以上比较繁琐地分析JSON的用途。

1、服务端使用JSON

可以使用C#以及其他扩展包提供的JSON操作函数来实现数据“序列化"——JSON把特定涵义的数据变成字节流,传递到客户端后,再按照JSON格式进行解释,完美!

方法很多:

JavaScriptSerializer 法

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Script.Serialization;
using TestWeb.Models;

namespace TestWeb.Controllers
{
    public class HomeController : Controller
    {
        //
        // GET: /Home/

        public ActionResult Index()
        {
           DataSet set= TestMysql.Query("select * from user");
           List<TestUser> list = new List<TestUser>();
           foreach (DataRow row in set.Tables[0].Rows)
           {
               TestUser tmp = new TestUser(row["name"].ToString(), 
                   row["psw"].ToString(), 
                   int.Parse(row["age"].ToString()));
               list.Add(tmp);
           }
           ViewBag.stu_list = list;

           JavaScriptSerializer jss = new JavaScriptSerializer();
           ViewBag.data = jss.Serialize(list);
            return View();
        }

    }
    public class TestUser
    {
        public string name;
        public string psw;
        public int age;
        public TestUser(string _name, string _psw, int _age)
        {
            name = _name;
            psw = _psw;
            age = _age;
        }
    }
}

页面:

<script>
    var msg = '@Html.Raw(ViewBag.data)';
    window.onload = function () {
      
        alert(msg);
    }
</script>

运行结果

要注意使用@Html.Raw 函数,页面如果改成:

<script>
    var msg = '@ViewBag.data';
    window.onload = function () {
      
        alert(msg);
    }
</script>

则运行结果为:

 很显然,对双引号的解释出了问题。

服务器JSON还有其他方法如:JSON.NET 和  扩展包Newtonsoft.Json

 ViewBag.data = JsonConvert.SerializeObject(list);

2、客户端JS使用JSON

代码:

<script>
    var msg = JSON.parse('@Html.Raw(ViewBag.data)');
    
    window.onload = function () {
        for (var i = 0; i < msg.length; i++) {
            alert("姓名:"+msg[i].name +" 年龄:"+msg[i].age +" 密码:"+msg[i].psw);
        }
        
    }
</script>

效果:

 很显然,浏览器对服务器传递的JSON字节流进行了正确的解释。

问题:

客户端是否可以将数据JSON序列化,传递到服务端控制器进行解释?当然可以,后续再探讨。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:main.m; Fig:GUI操作界面; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开main.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、语音处理系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等; CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:svddwt.m; 调用函数:其他m文件; 语音信号,其格式为MP4; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开svddwt.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、智能优化算法背包问题系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等;
### 回答1: ASP.NET MVC 5是一种基于MVC设计模式的Web应用程序框架,它能够帮助开发人员快速地构建高性能、可扩展、易于维护的Web应用程序。ASP.NET MVC 5的源代码是开放的,可以供开发人员学习和使用。 ASP.NET MVC 5的源代码包括了许多组件,如控制器、视图、路由、模型绑定、过滤器等,每个组件为开发人员提供了丰富的功能和灵活的扩展性。例如,控制器是ASP.NET MVC 5应用程序的核心组件之一,它包含了Action(处理客户端请求的方法)和ActionResult(请求的结果)等。视图是另一个重要的组件,它负责呈现数据并与用户交互。路由是整个应用的核心,负责将请求路由到对应的控制器和Action。 ASP.NET MVC 5的源代码还包含了许多其他的实用工具和库,如ASP.NET Identity(用户认证和授权)、Microsoft.AspNet.Web.Optimization(前端资源优化)、Web API(RESTful服务)等,这些工具和库能够帮助开发人员构建更加丰富和复杂的Web应用程序。 总之,ASP.NET MVC 5的源码是开放的,它提供了丰富的组件、实用的工具和库,可以帮助开发人员快速构建高性能、可扩展和易于维护的Web应用程序。开发人员可以通过学习源代码来了解框架的内部实现和功能特性,并逐步提升自己的开发技能。 ### 回答2: ASP.NET MVC 5是一种使用MVC模式(Mode-View-Controller)的Web应用程序框架。它是基于.NET Framework的,可以用于创建高性能、可扩展、安全的Web应用程序。 以下是ASP.NET MVC 5框架的主要源码揭秘: 1. Routing:路由是ASP.NET MVC应用程序中的一个重要概念。它用于将URL映射到特定的控制器和操作方法。MVC 5框架中的路由引擎根据请求的URL和路由模板来确定请求应该由哪个控制器和操作方法处理。 2. Controller:控制器是MVC模式中的一个组成部分,它负责处理用户请求并生成响应。在MVC 5框架中,控制器有许多基础类和接口,如Controller类、IController接口等。 3. View:视图是控制器生成响应的一部分,它将模型数据呈现为HTML页面。在MVC 5框架中,使用各种视图引擎来呈现视图,如Razor视图引擎、ASPX视图引擎等。 4. Model:模型是MVC模式中的最后一个组成部分,它在控制器和视图之间传递数据。在MVC 5框架中,使用各种模型绑定器来将请求数据绑定到模型。 5. Bundling and Minification:Bundling和Minification是ASP.NET MVC中常用的技术,用于减少页面加载时间和资源使用。在MVC 5框架中,通过使用System.Web.Optimization命名空间中的类来添加和管理JS、CSS和其他资源的捆绑和缩小。 总之,ASP.NET MVC 5是一种功能强大的Web应用程序框架,它实现了MVC模式并提供了许多特性和工具来帮助开发人员构建高性能、可扩展、安全的Web应用程序。通过深入了解和分析MVC 5框架的源代码,开发人员可以更好地理解其内部工作原理,从而更有效地使用和扩展它。 ### 回答3: ASP.NET MVC 5是一种用于构建Web应用的框架,它使用模型-视图-控制器(MVC)的设计模式。本文将介绍ASP.NET MVC 5的源代码。 ASP.NET MVC 5的源代码主要分为几个部分:框架核心、路由、控制器、视图和模型。 框架核心是ASP.NET MVC 5的核心部分,提供了MVC框架的基本功能。其中包括建立请求管道、控制器工厂和视图引擎等关键组件。框架核心的代码是相当庞大的,包含了许多类、接口和扩展方法。在了解整个框架的实现细节时,框架核心是一个重要的起点。 路由是控制请求流程的重要组成部分。ASP.NET MVC 5使用的是基于URL的路由,它将请求URL映射到相应的控制器和操作上。路由的源代码中,关键部分是路由表的维护和查询机制。在了解路由的实现细节时,了解路由表的数据结构和查询算法是必不可少的。 控制器是MVC框架中的核心组件,它负责处理请求并返回响应。控制器的实现代码通常非常简单,主要是一些Action方法的定义和调用。控制器的源代码中,需要关注的是Action的参数绑定、Model验证和ActionResult的实现细节等。 视图是MVC框架中的UI组件,它通过生成HTML代码来渲染页面。视图的源代码中,关键部分是视图引擎的实现,它根据视图的文件名和模板来生成HTML代码。在了解视图的实现细节时,视图引擎是一个重要的组成部分。 模型是应用程序中的数据模型,通常与数据库中的数据结构相关。模型的源代码中,重点是数据访问层和实体类型的定义。在了解数据模型的实现细节时,了解数据访问层的实现和实体类型的定义是必要的。 总之,ASP.NET MVC 5的源代码非常庞大,也非常复杂。要彻底掌握它,需要对框架的核心、路由、控制器、视图和模型等组成部分进行深入研究。同时,我们也需要了解C#编程语言和.NET平台的底层机制。只有这样,才能真正揭秘ASP.NET MVC 5的源代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

易老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值