将数据从一个 Razor 页面传递到另一个 Razor 页面

Pass Data From One Razor Page to Another Razor Page

提问人:MelB 提问时间:11/18/2023 最后编辑:Qing GuoMelB 更新时间:11/20/2023 访问量:44

问:

我需要一些帮助。我以前没有这样做过,我不完全确定在哪里添加什么。基本上,我正在开发一个应用程序来存储历史数据。无需创建、编辑或删除。这是为了打印宠物狂犬病证书。

我有一个宠物查看页面,其中包含宠物接种的疫苗。每次接种疫苗旁边都有一个按钮。我希望这个按钮链接到狂犬病证书页面,并在证书上填写该宠物和特定疫苗的数据(以便可以打印)。多年来,一只宠物可能已经接种了几种疫苗。

这是我到目前为止所拥有的(我已经消除了多余的字段来压缩帖子):

我的宠物详情页面:

@page
@using RabiesClinics.Model
@model RabiesClinics.Pages.Pets.DetailsModel

<form method="post">
    <div class="border p-3 mt-4">
        <div class="row pb-2">
            <h2 class="text-primary pl-3">Pet Details <img src="~/Images/PawPrints.png" /></h2>
            <hr />
        </div>
        <table class="table table-borderless" style="width:100%">
        <tr>
            <td style="width: 20%">
                <div class="mb-3">
                    <label asp-for="Pet.OwnerId"></label>
                    <input asp-for="Pet.OwnerId" disabled class="form-control" />
                </div>
            </td>
            <td style="width: 20%">
                <div class="mb-3">
                    <label asp-for="Pet.PetId"></label>
                    <input asp-for="Pet.PetId" disabled class="form-control" />
                </div>
            </td>
            <td style="width: 40%">
                <div class="mb-3">
                    <label asp-for="Pet.PetName"></label>
                    <input asp-for="Pet.PetName" type="text" disabled class="form-control"/>
                </div>
            </td>
            <td style="width: 20%">
                <div class="form-group, mb-3">
                    <label asp-for="Pet.Status"></label>
                    <br />
                    @foreach (var item1 in Html.GetEnumSelectList<Status>())
                    {
                        <input type="radio" disabled asp-for="Pet.Status" value="@item1.Text" />
                    @item1.Text
                    }
                </div>
            </td>
        </tr>
    </table>

        <hr />
        <h4>Vaccines</h4>
        <br />
        <table class="table table-bordered table-striped width:100%">
            <thead>
                <tr>
                    <th>
                        Date Vaxxed
                    </th>
                    <th>
                        Vax Expires
                    </th>
                    <th>
                        Vet Name
                    </th>
                    <th>
                        Print Rabies Certificate
                    </th>
                </tr>
            </thead>
            <tbody>
                @for (var i = 0; i < Model.Pet.Vaccines.Count; i++)
                {
                    <tr>
                        <td style="width: 10%">
                            <div class="mb-3">
                                <input asp-for="Pet.Vaccines[i].DateVaccinated" type="text" readonly class="form-control-plaintext" />
                            </div>
                        </td>
                        <td style="width: 10%">
                            <div class="mb-3">
                                <input asp-for="Pet.Vaccines[i].VaccinationExpiration" type="text" readonly class="form-control-plaintext" />
                            </div>
                        </td>
                        <td style="width: 20%">
                            <div class="mb-3">
                                <input asp-for="Pet.Vaccines[i].VetName" type="text" readonly class="form-control-plaintext" />
                            </div>
                        </td>
                        <td width="10%">
                            <div class="w-75 btn-group" role="group">
                                <a asp-page="/RabiesCertificates/Details" class="btn btn-primary mx-2">
                                    <i class="bi bi-printer"></i>
                                </a>
                            </div>
                        </td>
                    </tr>
                }
        </table>
        <div>
            <a asp-page="Index" class="btn btn-secondary" style="width: 150px;">Back to List</a>
        </div>
    </div>
</form>

@section Scripts{
    <partial name="_ValidationScriptsPartial"/>
}

以下是“宠物详细信息”页面的.cs:

using RabiesClinics.Data;
using RabiesClinics.Model;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.EntityFrameworkCore;

namespace RabiesClinics.Pages.Pets;

[BindProperties]

public class DetailsModel : PageModel
{
    private readonly ApplicationDbContext _db;
    
    public Pet Pet { get; set; }
    public Vaccine Vaccine { get; set; }
    
    public DetailsModel(ApplicationDbContext db)
    {
        _db = db;
    }

    public void OnGet(string Id)
    {
        Pet = _db.Pet
            .Include(pet => pet.Vaccines).FirstOrDefault(pet => pet.PetId == Id);

        var petid1 = Pet.PetId;
        var vaxdate1 = Vaccine.DateVaccinated;

    }

}

这是狂犬病证书页面的开头:

@page
@using RabiesClinics.Model
@model RabiesClinics.Pages.RabiesCertificates.DetailsModel

<div id="RabiesCertificateReports" class="container p-3">
    <div class="row pt-4">
        <div class="col-6">
            <h2 class="text-primary">Rabies Certificate</h2>
        </div>
    </div>

    <br /><br />

    <form asp-page="./Details" method="get">
        <div class="form-actions no-color">
            <p>
                <h5>Report Date Range</h5>
                For Pet Id: <input type="text" name="petid" value="" /> and Vaccine Date:<input type="date" name="vaxdate" value="" />
                <input type="submit" value="Filter Report" class="btn btn-primary mx-2" />
                <a asp-page="./Pets/Detail" class="btn btn-link mx-2">Return to Pet Detail</a>
            </p>
        </div>
        <div id="RabiesCertificate" class="row pt-4">
            <div class="col-25">
                <h2 class="text-primary; text-capitalize" align="center">RABIES VACCINATION CERTIFICATE</h2>
                <h3 class="text-primary; text-capitalize" align="center" style="font-style:italic">ADAPTED NASPHV FORM 51</h3>
                <h3 class="text-primary" align="center">Human Postexposure Rabies Treatment</h3>
                <h5 class="text-primary" align="center">@ViewData["endingparameter"]</h5>
            </div>

            <table class="table table-borderless" style="width:100%">
                <tr>
                    @foreach (var obj in Model.Filter)
                    {
                    <td style="width: 20%">
                        <div class="mb-3">
                            <label asp-for="@obj.LastName"></label>
                            <input asp-for="@obj.LastName" disabled class="form-control" />
                        </div>
                    </td>
                    <td style="width: 20%">
                        <div class="mb-3">
                            <label asp-for="@obj.FirstName"></label>
                            <input asp-for="@obj.FirstName" disabled class="form-control" />
                        </div>
                    </td>
                    <td style="width: 20%">
                        <div class="mb-3">
                            <label asp-for="@obj.Telephone"></label>
                            <input asp-for="@obj.Telephone" disabled class="form-control" />
                        </div>
                    </td>
                    }
                </tr>
            </table>
        </div>
    </form>
</div>

<button type="submit" onclick="printDiv('RabiesCertificate')" class="btn btn-primary" style="width:300px;">Print Rabies Certificate</button>

@section Scripts
    {
    <style>
        tr{
            text-align:right;
        }
    </style>

    <script language="javascript">
        function printDiv(divName) {
            var printContents = document.getElementById(divName).innerHTML;
            var originalContents = document.body.innerHTML;

            document.body.innerHTML = printContents;

            window.print();

            document.body.innerHTML = originalContents;
        }
    </script>
    }

以及狂犬病证书页面的.cs:

using RabiesClinics.Data;
using RabiesClinics.Model;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.EntityFrameworkCore;

namespace RabiesClinics.Pages.RabiesCertificates
{
    public class DetailsModel : PageModel
    {   
        private readonly ApplicationDbContext _db;

        public DetailsModel(ApplicationDbContext db)
        {
            _db = db;
        }

        public IEnumerable<Filter> Filter { get; set; }

        public async Task OnGetAsync(string petid, DateTime vaxdate)
        {
            var petid1 = petid;
            var vaxdate1 = vaxdate.ToShortDateString();

            ViewData["endingparameter"] = $"For Vaccination Date: {vaxdate1} and Pet Id: {petid1}";

            Filter = await (from x in _db.Owner
                            join y in _db.Pet on x.OwnerId equals y.OwnerId
                            join z in _db.Vaccine on x.OwnerId equals z.OwnerId
                            where y.PetId == petid && z.DateVaccinated == vaxdate
                            select new Filter
                            {
                                OwnerId = x.OwnerId,
                                PetId = y.PetId,
                                LastName = x.LastName,
                                FirstName = x.FirstName,
                                Telephone = x.Telephone,
                                Addr1 = x.Addr1,
                                Addr2 = x.Addr2,
                                City = x.City,
                                State = x.State,
                                Zip = x.Zip,
                                Species = y.Species,
                                Gender = y.Gender,
                                Altered = y.Altered,
                                Age = y.Age,
                                Breed = y.Breed,
                                PetName = y.PetName,
                                Colors = y.Colors,
                                DateVaccinated = (DateTime)z.DateVaccinated,
                                VaccinationExpiration = (DateTime)z.VaccinationExpiration,
                                ProducerId = z.ProducerId,
                                Duration = z.Duration,
                                VaccineLotNo = z.VaccineLotNo,
                                LotExpirationDate = (DateTime)z.LotExpirationDate,
                                VetLicenseNo = z.VetLicenseNo,
                                VetName = z.VetName,
                                VetAddress = z.VetAddress,
                            }).ToListAsync();
        }

    }
}

我在这里查看了其他几篇文章,但对回复/答案的理解不够好,不知道在我自己的代码中放什么。

谢谢!!

ASP.NET 核心 变量 参数传递 ViewModel 剃须刀页

评论


答:

1赞 Qing Guo 11/20/2023 #1

您可以在宠物详细信息中使用 ViewData[“petid1”] .cs:

 ViewData["petid1"] = Pet.PetId;

然后尝试使用以下代码:<a>asp-route-{value}

<a  asp-page="/RabiesCertificates/Details" class="btn btn-primary mx-2" asp-route-petid="@ViewData["petid1"]" asp-route-vaxdate="@Model.Pet.Vaccines[i].DateVaccinated">
    <i class="bi bi-printer"></i>
</a>

result:enter image description here您可以阅读 asp-route-{value} 以了解更多信息。