Dieser Artikel ist ein Spiegelartikel der maschinellen Übersetzung, bitte klicken Sie hier, um zum Originalartikel zu springen.

Ansehen: 14302|Antwort: 0

[ASP.NET] MVC implementiert eine Fortschrittsleiste zur Zeit, indem sie die Fortschrittsleiste der jQuery-Benutzeroberfläche nutzt

[Link kopieren]
Veröffentlicht am 05.10.2015 16:05:23 | | | |
In E-Commerce-Websites wird die Fortschrittsleiste manchmal verwendet, um visuell anzuzeigen, ob ein Nutzer fällig ist und wie der aktuelle Status des Nutzers ist.

Entwerfen Sie ein solches Modell.

  1. public class User
  2.     {
  3.         public int Id { get; set; }
  4.         public string Name { get; set; }
  5.         public int CoopTime { get; set; }
  6.         public DateTime JoinTime { get; set; }
  7.     }
Code kopieren
Das oben Genannte ist das Kooperationsdauer-Attribut CoopTime und das Jointime-Attribut JoinTime zwei Attribute, die eng mit dem Fortschritt verbunden sind.

In HomeController wird eine Aktionsmethode verwendet, um die Schnittstelle anzuzeigen, und eine Aktionsmethode wird verwendet, um GET-Anfragen aus der View- und Rücksendungs-JSON-Daten zu empfangen.
  1. public ActionResult Index()
  2.         {
  3.             return View();
  4.         }
  5.         public ActionResult GetStatus()
  6.         {
  7.             User user = new User()
  8.             {
  9.                 Id = 1,
  10.                 Name = "某某用户",
  11.                 CoopTime = 1,
  12.                 JoinTime = new DateTime(2014, 3, 20)
  13.             };
  14.             //判断合作是否已经到期
  15.             int result = DateTime.Compare(DateTime.Now, user.JoinTime.AddYears(user.CoopTime));
  16.             if (result <= 0) //当前时间比合作到期时间早,合作未到期
  17.             {
  18.                 //计算时间
  19.                 var pastDays = (DateTime.Now.Subtract(user.JoinTime)).TotalDays;
  20.                 var oneYearDays = (user.JoinTime.AddYears(user.CoopTime).Subtract(user.JoinTime)).TotalDays;
  21.                 var pastPercentage = (pastDays / oneYearDays) * 100;
  22.                 var dataSuccess = new { msg = true, p = pastPercentage };
  23.                 return Json(dataSuccess, JsonRequestBehavior.AllowGet);
  24.             }
  25.             else //当前时间比合作到期时间晚,合作已到期
  26.             {
  27.                 var dataFail = new { msg = false, p = 100 };
  28.                 return Json(dataFail, JsonRequestBehavior.AllowGet);
  29.             }
  30.         }
  31.     }
Code kopieren
Oben,
● Verwenden Sie die statische Methode DateTime Compare zum Vergleichen von 2 Zeiten, eines ist die aktuelle Zeit, das andere die Join-Zeit + Kooperationsdauer. Wenn das Ergebnis kleiner oder gleich 0 ist, bedeutet das, dass kein Ablauf vorliegt.
● Verwenden Sie die statische Methode DateTime, Subtrahieren, um 2 Mal abzuziehen.

Home/Index.cshtml senden Sie beim Laden der Seite eine asynchrone GET-Anfrage an den Server, um die zurückgegebenen Daten in der Fortschrittsleiste anzuzeigen.
  1. <head>
  2.     <meta name="viewport" content="width=device-width" />
  3.     <title>Index</title>
  4.     <link href="~/Content/themes/base/jquery-ui.css" rel="stylesheet" />
  5.     <scrip{过滤}t src="~/scrip{过滤}ts/jquery-1.8.2.min.js"></scrip{过滤}t>
  6.     <scrip{过滤}t src="~/scrip{过滤}ts/jquery-ui-1.8.24.min.js"></scrip{过滤}t>
  7.     <scrip{过滤}t type="text/javascrip{过滤}t">
  8.         $(function () {
  9.             
  10.             $.getJSON('@Url.Action("GetStatus","Home")', function(data) {
  11.                 if (data.msg == true) {
  12.                     var temp = parseInt(data.p);
  13.                     $('#p').progressbar({
  14.                         value: temp
  15.                     });
  16.                 } else {
  17.                     $('#message').text('已到期');
  18.                     $('#p').progressbar({
  19.                         value: parseInt(data.p)
  20.                     });
  21.                 }
  22.             });
  23.         });
  24.     </scrip{过滤}t>
  25. </head>
  26. <body>
  27.     <div id="p">      
  28.     </div>
  29.     <div>
  30.         <span id="message"></span>
  31.     </div>
  32. </body>
Code kopieren






Vorhergehend:Nutzen Sie die neue Version von Baidu Cloud, um den Schutz von Websites zu beschleunigen und Nicht-CDN-IP-Adressen am Zugriff auf Websites zu blockieren
Nächster:SoftEther VPN Client ist eine wirklich kostenlose VPN-Software
Verzichtserklärung:
Alle von Code Farmer Network veröffentlichten Software, Programmiermaterialien oder Artikel dienen ausschließlich Lern- und Forschungszwecken; Die oben genannten Inhalte dürfen nicht für kommerzielle oder illegale Zwecke verwendet werden, andernfalls tragen die Nutzer alle Konsequenzen. Die Informationen auf dieser Seite stammen aus dem Internet, und Urheberrechtsstreitigkeiten haben nichts mit dieser Seite zu tun. Sie müssen die oben genannten Inhalte innerhalb von 24 Stunden nach dem Download vollständig von Ihrem Computer löschen. Wenn Ihnen das Programm gefällt, unterstützen Sie bitte echte Software, kaufen Sie die Registrierung und erhalten Sie bessere echte Dienstleistungen. Falls es eine Verletzung gibt, kontaktieren Sie uns bitte per E-Mail.

Mail To:help@itsvse.com