Tämä artikkeli on konekäännöksen peiliartikkeli, klikkaa tästä siirtyäksesi alkuperäiseen artikkeliin.

Näkymä: 14302|Vastaus: 0

[ASP.NET] MVC toteuttaa edistymispalkin ajasta käyttäen jQueryn käyttöliittymän edistymispalkkia

[Kopioi linkki]
Julkaistu 5.10.2015 16.05.23 | | | |
Verkkokaupoilla edistymispalkkia käytetään joskus visuaalisesti näyttämään, onko käyttäjä erääntynyt ja käyttäjän nykyinen tila.

Suunnittele tällainen malli.

  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.     }
Kopioi koodi
Yllä oleva on yhteistyön kesto-attribuutti CoopTime ja jointime-attribuutti JoinTime ovat kaksi attribuuttia, jotka liittyvät läheisesti edistymiseen.

HomeControllerissa käyttöliittymän näyttämiseen käytetään toimintometodia, ja toimintomenetelmää käytetään GET-pyyntöjen vastaanottamiseen näkymästä ja json-tietojen palauttamiseen.
  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.     }
Kopioi koodi
Yllä,
● Käytä staattista DateTime Compare -menetelmää vertaillaksesi kahta kertaa, toinen on nykyinen aika, toinen on liitosaika + yhteistyön kesto; jos tulos on pienempi tai yhtä suuri kuin 0, se tarkoittaa, ettei vanhenemista.
● Käytä staattista DateTime-menetelmää, vähennetään kaksi kertaa.

Home/Index.cshtml, kun sivu on ladattu, lähetä palvelimelle asynkroninen GET-pyyntö, joka näyttää palautetut tiedot edistymispalkissa.
  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>
Kopioi koodi






Edellinen:Käytä uutta Baidu Cloudin versiota verkkosivustojen suojaamisen nopeuttamiseen ja ei-CDN-IP-osoitteiden pääsyn estämiseen verkkosivustoille
Seuraava:SoftEther VPN Client on aidosti ilmainen VPN-ohjelmisto
Vastuuvapauslauseke:
Kaikki Code Farmer Networkin julkaisemat ohjelmistot, ohjelmamateriaalit tai artikkelit ovat tarkoitettu vain oppimis- ja tutkimustarkoituksiin; Yllä mainittua sisältöä ei saa käyttää kaupallisiin tai laittomiin tarkoituksiin, muuten käyttäjät joutuvat kantamaan kaikki seuraukset. Tämän sivuston tiedot ovat peräisin internetistä, eikä tekijänoikeuskiistat liity tähän sivustoon. Sinun tulee poistaa yllä oleva sisältö kokonaan tietokoneeltasi 24 tunnin kuluessa lataamisesta. Jos pidät ohjelmasta, tue aitoa ohjelmistoa, osta rekisteröityminen ja hanki parempia aitoja palveluita. Jos rikkomuksia ilmenee, ota meihin yhteyttä sähköpostitse.

Mail To:help@itsvse.com