Šis raksts ir mašīntulkošanas spoguļraksts, lūdzu, noklikšķiniet šeit, lai pārietu uz oriģinālo rakstu.

Skats: 14302|Atbildi: 0

[ASP.NET] MVC ievieš progresa joslu par laiku, izmantojot jQuery lietotāja interfeisa progresa joslu

[Kopēt saiti]
Publicēts 05.10.2015 16:05:23 | | | |
E-komercijas vietnēs norises josla dažkārt tiek izmantota, lai vizuāli parādītu, vai lietotājam ir jāmaksā un lietotāja pašreizējais statuss.

Izstrādājiet šādu modeli.

  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.     }
Kopēt kodu
Iepriekš minētais ir sadarbības ilguma atribūts CoopTime un jointime atribūts JoinTime ir divi atribūti, kas ir cieši saistīti ar progresu.

Programmā HomeController interfeisa parādīšanai tiek izmantota darbības metode, un darbības metode tiek izmantota, lai saņemtu GET pieprasījumus no skata un atgrieztu json datus.
  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.     }
Kopēt kodu
Iepriekš,
● Izmantojiet statisko DateTime Compare metodi, lai salīdzinātu 2 reizes, viena ir pašreizējais laiks, otra ir pievienošanās laiks + sadarbības ilgums, ja rezultāts ir mazāks vai vienāds ar 0, tas nozīmē, ka nav derīguma termiņa.
● Izmantojiet statisko metodi DateTime, Atņemt, lai atņemtu 2 reizes.

Home/Index.cshtml, kad lapa ir ielādēta, nosūtiet serverim asinhronu GET pieprasījumu, lai parādītu atgrieztos datus progresa joslā.
  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>
Kopēt kodu






Iepriekšējo:Izmantojiet jauno Baidu Cloud versiju, lai paātrinātu vietņu aizsardzību un bloķētu piekļuvi vietnēm, kas nav CDN
Nākamo:SoftEther VPN klients ir patiesi bezmaksas VPN programmatūra
Atruna:
Visa programmatūra, programmēšanas materiāli vai raksti, ko publicē Code Farmer Network, ir paredzēti tikai mācību un pētniecības mērķiem; Iepriekš minēto saturu nedrīkst izmantot komerciāliem vai nelikumīgiem mērķiem, pretējā gadījumā lietotājiem ir jāuzņemas visas sekas. Informācija šajā vietnē nāk no interneta, un autortiesību strīdiem nav nekāda sakara ar šo vietni. Iepriekš minētais saturs ir pilnībā jāizdzēš no datora 24 stundu laikā pēc lejupielādes. Ja jums patīk programma, lūdzu, atbalstiet oriģinālu programmatūru, iegādājieties reģistrāciju un iegūstiet labākus oriģinālus pakalpojumus. Ja ir kādi pārkāpumi, lūdzu, sazinieties ar mums pa e-pastu.

Mail To:help@itsvse.com