douqiang5933 2018-01-06 17:48
浏览 46
已采纳

在ajax之后覆盖页面缓存

I haven't been able to find a straightforward answer for this question.

I have an admin panel that shows extra options if the user inputs a password. If the password is correct, these extra options are appended to the page.

Admin Panel w/password input: Regular admin panel w/second password input

Javascript that loads the super admin options and appends them to the page:

  function showAdminOptions(e) {
    e.preventDefault();
    var data = new FormData();
    data.append('additional_password', document.getElementById('additional_password').value);
    var xhr = new XMLHttpRequest();
    xhr.open('POST', 'show_admin_options.php', true);
    xhr.withCredentials = true;
    xhr.onload = function() {
      if (xhr.status >= 200 && xhr.status < 400) {
        // Success!
        document.getElementById('show_admin_options').innerHTML = xhr.responseText;
      } else {
        alert("ERROR");
      }
    };
    xhr.onerror = function() {
      alert("ERROR");
    };
    xhr.send(data);
  }

NOTE: If the password is correct, the markup for the extra options is returned from show_admin_options.php.

Admin panel w/extra options, after inputting correct password: Admin Panel w/extra options

The problem is, when someone who has inputed the correct password navigates away from the page and then hits the back button, it loads the original version of the admin page w/out the extra options.

What can I do to make the cache save the page in it's state w/extra options?

  • 写回答

1条回答 默认 最新

  • duanqinbi9029 2018-03-13 14:40
    关注

    MY SOLUTION

    I decided to just forget about doing this asynchronously, and made the form submit with a method of POST, and an action of the same url. The PHP template then renders the admin options using the $_SESSION variable that was set.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改