0

0

通过ASP.NET Core的href链接从视图向控制器传递数据

聖光之護

聖光之護

发布时间:2025-10-13 11:49:46

|

1000人浏览过

|

来源于php中文网

原创

通过asp.net core的href链接从视图向控制器传递数据

本文旨在讲解如何在ASP.NET Core MVC应用程序中,通过``标签(href链接)将数据从视图传递到控制器。我们将详细介绍如何使用`asp-route-{parameterName}`属性以及如何在控制器中接收这些数据,并提供清晰的代码示例,帮助开发者轻松实现数据传递。

在ASP.NET Core MVC中,通过链接 (<a> 标签) 将数据从视图传递到控制器是一个常见的需求。 asp-route-{parameterName} 属性提供了一种简洁而强大的方式来实现这一目标。 本文将详细介绍如何使用此属性以及如何在控制器中接收传递的数据。

使用 asp-route-{parameterName} 属性

asp-route-{parameterName} 属性允许你将数据作为路由参数添加到链接的URL中。 {parameterName} 部分可以替换为你想要的任何名称,这个名称将对应于控制器方法中的参数名称。

示例:

假设你有一个名为 question 的对象,并且你想将 Questionaire 属性的值传递给 ViewOthersProfile 操作方法。 你可以使用以下代码:

<a asp-action="ViewOthersProfile" asp-route-questionaire="@question.Questionaire">@question.Questionaire</a>

在这个例子中,asp-route-questionaire 将 question.Questionaire 的值作为名为 questionaire 的路由参数添加到链接的URL中。 生成的URL可能类似于:/ViewOthersProfile?questionaire=SomeValue。

注意: asp-route-* 属性会自动进行 URL 编码,因此你无需手动对数据进行编码。

在控制器中接收数据

要在控制器中接收通过 asp-route-{parameterName} 传递的数据,你需要在相应的操作方法中定义一个与路由参数名称匹配的参数。

示例:

[HttpGet]
public ViewResult ViewOtherProfile(string questionaire)
{
  // 现在你可以在这里使用 questionaire 变量
  string result = "Questionaire: " + questionaire;
  ViewBag.Result = result;
  return View("OtherProfile");
}

在这个例子中,ViewOtherProfile 方法接收一个名为 questionaire 的字符串参数。 ASP.NET Core MVC 会自动将 URL 中的 questionaire 路由参数的值绑定到此参数。 现在,你可以在方法中使用 questionaire 变量来执行任何需要的操作。

叮当好记-AI音视频转图文
叮当好记-AI音视频转图文

AI音视频转录与总结,内容学习效率 x10!

下载

重要事项:

  • 参数名称必须匹配: 控制器方法中的参数名称必须与 asp-route-{parameterName} 属性中的 {parameterName} 部分完全匹配(大小写敏感)。
  • HTTP 方法: 确保使用正确的 HTTP 方法(例如 HttpGet)来处理请求。 通常,通过链接传递数据使用 HttpGet 方法。
  • 数据类型: 控制器方法中的参数的数据类型应与传递的数据类型兼容。 如果传递的是数字,则可以使用 int、double 等数据类型。 如果传递的是日期,则可以使用 DateTime 数据类型。 ASP.NET Core MVC 会尝试自动进行类型转换。

完整示例

以下是一个完整的示例,演示如何通过链接将数据从视图传递到控制器:

视图 (例如:Index.cshtml):

@model MyViewModel

<ul>
    @foreach (var question in Model.Questions)
    {
        <li>
            <a asp-action="ViewOthersProfile" asp-route-questionaire="@question.Questionaire">@question.Questionaire</a>
        </li>
    }
</ul>

模型 (例如:MyViewModel.cs):

public class MyViewModel
{
    public List<Question> Questions { get; set; }
}

public class Question
{
    public string Questionaire { get; set; }
}

控制器 (例如:HomeController.cs):

using Microsoft.AspNetCore.Mvc;
using System.Collections.Generic;

public class HomeController : Controller
{
    public IActionResult Index()
    {
        var model = new MyViewModel
        {
            Questions = new List<Question>
            {
                new Question { Questionaire = "Question 1" },
                new Question { Questionaire = "Question 2" }
            }
        };
        return View(model);
    }

    [HttpGet]
    public IActionResult ViewOtherProfile(string questionaire)
    {
        ViewBag.Questionaire = questionaire;
        return View("OtherProfile"); // 创建一个名为 OtherProfile 的视图
    }
}

OtherProfile 视图 (例如:OtherProfile.cshtml):

<h1>Other Profile</h1>
<p>Questionaire: @ViewBag.Questionaire</p>

在这个示例中,Index 视图循环遍历 Questions 列表,并为每个问题创建一个链接。 当用户单击链接时,Questionaire 属性的值将作为路由参数传递给 ViewOtherProfile 操作方法。 ViewOtherProfile 方法接收 questionaire 参数,并将其传递给 OtherProfile 视图,最终显示在页面上。

总结

asp-route-{parameterName} 属性是ASP.NET Core MVC中一种方便且强大的方式,用于通过链接将数据从视图传递到控制器。 通过正确使用此属性和在控制器中定义匹配的参数,你可以轻松地在应用程序的不同部分之间传递数据。 请记住,参数名称必须匹配,并且使用正确的 HTTP 方法。 通过遵循这些准则,你可以避免常见错误并确保数据正确传递。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

338

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

225

2025.10.31

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

138

2026.02.12

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1570

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

651

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1269

2024.03.22

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.7万人学习

AngularJS教程
AngularJS教程

共24课时 | 4.2万人学习

CSS教程
CSS教程

共754课时 | 44.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号