passing several parameters through url to the same page in A

passing several parameters through url to the same page in ASP MVC & Javascript

本文关键字:same page in the to several parameters through url passing      更新时间:2023-09-26

我是网络问题的新手,正在寻求建议。我想做的是:

1-页面中有一个日期选择器,其中有几个javascript帖子

2-当页面第一次打开时,post方法应该用初始值调用

3-当我从Datepicker更改日期间隔并按下Submit按钮时,页面应该用新值刷新,因此帖子应该用新的值再次触发。

4-当页面用新值刷新时,我希望日期选择器输入部分(有2个(显示更新的值。

5-目前,没有初始值。此外,这份清单上的第4项也不见了

我知道这里缺少了一些基本的东西,但我无法通过问题找到答案,因为我不知道系统是如何工作的。有人能帮我修改一下代码吗?

这是Datepicker及其JS部分:

<li>
    <div class="input-daterange input-group" id="datepicker" style="margin-top: 10px; align-content:center">
        <input type="text" class="input-sm form-control" id="startDate" value="07/01/2015" maxlength="10" name="start" style="width:90px" />
        <span class="input-group-addon">ile</span>
        <input type="text" class="input-sm form-control" id="endDate" value="07/05/2015" maxlength="10" name="end" style="width:90px" />
    </div>
</li>
<li>
    <button id="goster" type="button" class="btn btn-default" onclick="goster()"
            style="background-color:#C71F45;color:white;
            margin-top:10px; margin-left:10px">
            Göster
    </button>
</li>
<script>
   function goster() {
        startDate = document.getElementById('startDate').value;
        endDate = document.getElementById('endDate').value;
        var url = "http://localhost:50523/Home/Index?startDate=" + startDate + "&endDate=" + endDate;
        window.location.replace(url);
    }
</script>
<script>
    $(document).ready(function () {
        var QueryString = function () {
            // This function is anonymous, is executed immediately and 
            // the return value is assigned to QueryString!
            var query_string = {};
            var query = window.location.search.substring(1);
            var vars = query.split("&");
            for (var i = 0; i < vars.length; i++) {
                var pair = vars[i].split("=");
                // If first entry with this name
                if (typeof query_string[pair[0]] === "undefined") {
                    query_string[pair[0]] = decodeURIComponent(pair[1]);
                    // If second entry with this name
                } else if (typeof query_string[pair[0]] === "string") {
                    var arr = [query_string[pair[0]], decodeURIComponent(pair[1])];
                    query_string[pair[0]] = arr;
                    // If third or later entry with this name
                } else {
                    query_string[pair[0]].push(decodeURIComponent(pair[1]));
                }
            }
            return query_string;
        }();
        $('.input-daterange').datepicker({
            format: "mm/dd/yyyy",
            autoclose: true,
            language: "tr",
            orientation: "top auto",
            todayHighlight: true
        });
        var startDate = QueryString.startDate;
        var endDate = QueryString.endDate;
        $.post(
            "/api/getUserTotalExp?startDate=" + startDate + "&endDate=" + endDate,
            { data: {} },
            function (data) {
                $('#totaluserexp').html(data + " saat");
            }
        );
        $.post(
             "/api/getUserExpDaily?startDate=" + startDate + "&endDate=" + endDate,
             { data: {} },
             function (data) {
                 ...
             }
        );
    });
</script>
  1. 只需要一个onReady(你做到了(
  2. 将代码放在代码中,而不是放在标记中(goster((调用(
  3. 由于$.post实际上是一个ajax快捷方式,我将把它分解为位,这样我们也许可以更优雅地处理数据。(I使用它将.done promise放在jqXHR上以使用(当ajax成功完成(
  4. 日期选择器不在输入上是不是很奇怪?也许我不知道但我会把它们放在输入上(你在现实取决于你
  5. 将CSS/样式从标记中移除(由您决定(
  6. 用帖子/页面刷新来解决这个问题——把它放在cookie中(谷歌一下,也许建议使用$.cookie插件?(

标记和代码:

<li>
    <div class="input-daterange input-group" id="datepicker" style="margin-top: 10px; align-content:center">
        <input type="text" class="input-sm form-control" id="startDate" value="07/01/2015" maxlength="10" name="start" style="width:90px" /> <span class="input-group-addon">ile</span>
        <input type="text" class="input-sm form-control" id="endDate" value="07/05/2015" maxlength="10" name="end" style="width:90px" />
    </div>
</li>
<li>
    <button id="goster" type="button" class="btn btn-default" style="background-color:#C71F45;color:white;
            margin-top:10px; margin-left:10px">Göster</button>
</li>

和代码:

$(document).ready(function () {
    $('#goster').on('click', function () {
        var startDate = $('#startDate').val();
        var endDate = $('#endDate').val();
        goster(startDate, endDate);
    });
    $('input.input-sm').datepicker({
        format: "mm/dd/yyyy",
        autoclose: true,
        language: "tr",
        orientation: "top auto",
        todayHighlight: true
    });
    function goster(startDate, endDate) {
        PostUserExp(startDate, endDate);
    }
    function PostUserExp(startDate, endDate) {
        //var startDate = $('#startDate').val();
        //var endDate = $('#endDate').val();
        var myajaxExp = $.ajax({
            url: "/api/getUserTotalExp",
            data: {
                "startDate": startDate,
                    "endDate": endDate
            }
        });
        myajaxExp.done(function (data, textStatus, jqXHR) {
            // what to do with data
            $('#totaluserexp').html(data + "saat");
        });
        var myajaxDaily = $.ajax({
            url: "/api/getUserExpDaily",
            data: {
                "startDate": startDate,
                    "endDate": endDate
            }
        });
        myajaxDaily.done(function (data, textStatus, jqXHR) {
            // what to do with data
            $('#totaluserexp').html(data + "saat");
        });
    }
    var startDate = $('#startDate').val();
    var endDate = $('#endDate').val();
    PostUserExp(startDate, endDate)
});
$.post("/api/getUserExpDaily", 
  {
    'startDate': startDate,
    'endDate': endDate
  },
  function (data) {
    ....
  });

编辑:数据:{…}是一个拼写错误。哦,好吧。

这将始终使用jQuery来格式化您的日期。现在,如果您的服务器期望JSON,那么这是一个稍微不同的问题。但是,上面的代码应该适用于您的情况。

https://developer.chrome.com/devtools网络选项卡将允许您检查您的帖子。如果您查找getUserExpDaily POST这一行。然后,您可以检查代码中的值、格式和响应。