基于Jquery.history解决ajax的前进后退问题
本文主要给大家介绍基于Jquery.history解决ajax的前进后退问题,涉及到jquery前进后退相关方面的知识,本文内容经典,非常具有参考价值,特此把jquery前进后退相关知识分享在脚本之家网站供大家参考
以下内容是关于Jquery.history解决ajax的前进后退问题,具体详情请看下文。
本文的前提是基于后台的,所以这里不会考虑seo的问题。同时,基于后台的管理系统,也不需要被收藏,所以也不会考虑刷新的这种类似直接敲网址的情况!!!
这里使用的是html5中的history.state 来解决。
网上已经有了js的开源解决方案pushState。详见pjax
但是这个方案不适合我的项目(后台项目),尤其是主要的方法有点不够用。
我使用的是 jquery.history.js 可以参考这个 history.js
看下面的代码
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <script src="http://libs.baidu.com/jquery/1.9.1/jquery.min.js"></script> <script src="js/jquery.history.js"></script> </head> <body>
用户名
用户id
显示结果
<p id="ptxtinfo"><input id="txtinfo" type="text"/></p> <br/> <a funname="displayinfo" title="wxq" href="javascript:void(0);" class="apjax">提交</a> <br/> log: <textarea id="log" style="width:100%;height:400px"></textarea> </body> </html> <script> ///随机数 function guid() { function S4() { return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1); } return (S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4()); } /// 回调的方法 function doCallback(fn, args) { fn.apply(this, args); } ///获取查询字符串 function GetQueryString() { var result = ""; var url = location.href; if(url.indexOf("?")>0){ result = url.substring(url.indexOf("?") + 1, url.length); if (result != "") { result = result + "&"; } } return "?" + result; } // 用来保存地址栏的参数,第一次页面加载的时候执行。 用来修改地址栏的时候,保留原始的参数 var globalQuerystr; var golbalState = { "globalPara": {},// js调用方法执行时用的全局js参数, "globalControlValue": {},//js需要修改value的html组件 如文本 类似$(“#xxx”).val() "globalControlHtml": {},// js需要修改内部html内容的html组件 类似 $(“#yy”).html() "CallbackFunctions": "" // 回调的js方法 可以自己实现 ,用逗号分隔,一般是一个方法名 }; ///全局变量的问题 globaPara 保存全局变量 ///多个控件变化 但是不在一个容器内的问题 数组的方式 History.pushState({state:1,rand:Math.random(), "globaPara":globaPara, "valuecontrol":[{"txtuser":"1"},{"txtname":"2"}] "htmlcontrol":[{"htmltxt":"<b>hello</b>"},{"htmlcheckbox1":""}] },"title","?data=1" //控件类型的问题 有的保存值就行 有的保存html更方便 (function (window, undefined) { globalQuerystr = GetQueryString(); var History = window.History, // Note: We are using a capital H instead of a lower h State = History.getState(), $log = $('#log'); console.info("页面加载完毕"); History.log('initial:', State.data, State.title, State.url); //页面第一次加载的时候 State没有属性 History.Adapter.bind(window, 'statechange', function () { // Note: We are using statechange instead of popstate // Log the State var State = History.getState(); // Note: We are using History.getState() instead of event.state golbalState = State.data; if (golbalState) { //修改控件的val值 if (golbalState.globalControlValue) { for (var i = 0; i < golbalState.globalControlValue.length; i++) { $("#" + golbalState.globalControlValue[i].controlid).val(golbalState.globalControlValue[i].controlvalue); } } //修改全局变量 if (golbalState.globalPara) { for (var i = 0; i < golbalState.globalPara.length; i++) { eval("" + golbalState.globalPara[i].globalname + " =" + golbalState.globalPara[i].globalvalue + ";"); } } //修改控件的html if (golbalState.globalControlHtml) { for (var i = 0; i < golbalState.globalControlHtml.length; i++) { $("#" + golbalState.globalControlHtml[i].controlid).html(golbalState.globalControlHtml[i].controlhtml); } } //执行恢复参数后要执行的函数 if (golbalState.CallbackFunctions != "") { doCallback(eval("" + golbalState.CallbackFunctions), null); } //清空函数 golbalState.CallbackFunctions = ""; } History.log('statechange:', State.data, State.title, State.url); }); })(window); function displayinfo() { console.info("index:" + History.getCurrentIndex); //ajax方法,从服务器获取数据 $("#txtinfo").val("我爱" + $("#txtUser").val() + $("#txtId").val()); } $(function () { $(".apjax").on("click", function () { golbalState.globalControlValue = [{"controlid": "txtUser", "controlvalue": $("#txtUser").val()}]; golbalState.CallbackFunctions = $(this).attr("funname"); History.pushState(golbalState, $(this).attr("title"), globalQuerystr + "rnd=" + guid()); }); }) </script>
一 先引用jquery 和history.js 的js
二
History.Adapter.bind(window, 'statechange', function () { 表示在点击后退 前进或history的js方法时,监控变化。当变化时执行自定义的方法。
History.pushState 有三个参数 state title 自定义的地址查询参数。
该方法往历史记录里添加数据,修改地址栏
History.getState() 获取当前地址的state参数
三 流程
1 首先获取地址栏的参数并保存
2 绑定包含apjax类的标记的click方法, 标记可以任意,可以是p a链接 按钮等
当点击的时候,保存执行ajax方法前的状态,保存到golbalState ,其中回调的方法从标记的funname属性中调取,title的值从标记的title属性获取,
“globalPara": "globalControlValue": "globalControlHtml 最好在ajax的方法中赋值,如displayinfo
3 History.pushState 添加到历史记录,并修改地址栏
4 当后退的时候,执行History.Adapter.bind中的方法,先获取state参数
5 把之前 js修改过的变量修改回原来的值 ,把之前修改的html组件的value的值改回原来的值,把修改过的html组件中的html内容恢复为原来的值,
6 重新执行原来的执行过的方法, 即CallbackFunctions中保存的方法。
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
使用HTML5中postMessage知识点解决Ajax中POST跨域问题
关于ajax对象一些常用属性、事件和方法大小写比较常见的问题总结
Atas ialah kandungan terperinci 基于Jquery.history解决ajax的前进后退问题. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Tajuk: Kaedah dan contoh kod untuk menyelesaikan ralat 403 dalam permintaan AJAX jQuery Ralat 403 merujuk kepada permintaan bahawa pelayan melarang akses kepada sumber Ralat ini biasanya berlaku kerana permintaan itu tidak mempunyai kebenaran atau ditolak oleh pelayan. Apabila membuat permintaan jQueryAJAX, anda kadangkala menghadapi situasi ini Artikel ini akan memperkenalkan cara menyelesaikan masalah ini dan memberikan contoh kod. Penyelesaian: Semak kebenaran: Mula-mula pastikan alamat URL yang diminta adalah betul dan sahkan bahawa anda mempunyai kebenaran yang mencukupi untuk mengakses sumber tersebut.

jQuery ialah perpustakaan JavaScript popular yang digunakan untuk memudahkan pembangunan sisi klien. AJAX ialah teknologi yang menghantar permintaan tak segerak dan berinteraksi dengan pelayan tanpa memuatkan semula keseluruhan halaman web. Walau bagaimanapun, apabila menggunakan jQuery untuk membuat permintaan AJAX, anda kadangkala menghadapi 403 ralat. Ralat 403 biasanya ralat akses yang dinafikan pelayan, mungkin disebabkan oleh dasar keselamatan atau isu kebenaran. Dalam artikel ini, kami akan membincangkan cara menyelesaikan permintaan jQueryAJAX yang menghadapi ralat 403

Menggunakan Ajax untuk mendapatkan pembolehubah daripada kaedah PHP adalah senario biasa dalam pembangunan web Melalui Ajax, halaman boleh diperoleh secara dinamik tanpa menyegarkan data. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Ajax untuk mendapatkan pembolehubah daripada kaedah PHP, dan memberikan contoh kod khusus. Pertama, kita perlu menulis fail PHP untuk mengendalikan permintaan Ajax dan mengembalikan pembolehubah yang diperlukan. Berikut ialah kod contoh untuk fail PHP mudah getData.php:

Bagaimana untuk menyelesaikan masalah jQueryAJAX ralat 403? Apabila membangunkan aplikasi web, jQuery sering digunakan untuk menghantar permintaan tak segerak. Walau bagaimanapun, kadangkala anda mungkin menghadapi kod ralat 403 apabila menggunakan jQueryAJAX, menunjukkan bahawa akses dilarang oleh pelayan. Ini biasanya disebabkan oleh tetapan keselamatan bahagian pelayan, tetapi terdapat cara untuk mengatasinya. Artikel ini akan memperkenalkan cara menyelesaikan masalah ralat jQueryAJAX 403 dan memberikan contoh kod khusus. 1. membuat

Bina enjin cadangan autolengkap menggunakan PHP dan Ajax: Skrip sisi pelayan: mengendalikan permintaan Ajax dan mengembalikan cadangan (autocomplete.php). Skrip pelanggan: Hantar permintaan Ajax dan cadangan paparan (autocomplete.js). Kes praktikal: Sertakan skrip dalam halaman HTML dan nyatakan pengecam elemen input carian.

Ajax (JavaScript Asynchronous dan XML) membenarkan menambah kandungan dinamik tanpa memuatkan semula halaman. Menggunakan PHP dan Ajax, anda boleh memuatkan senarai produk secara dinamik: HTML mencipta halaman dengan elemen kontena dan permintaan Ajax menambah data pada elemen selepas memuatkannya. JavaScript menggunakan Ajax untuk menghantar permintaan kepada pelayan melalui XMLHttpRequest untuk mendapatkan data produk dalam format JSON daripada pelayan. PHP menggunakan MySQL untuk menanyakan data produk daripada pangkalan data dan mengekodnya ke dalam format JSON. JavaScript menghuraikan data JSON dan memaparkannya dalam bekas halaman. Mengklik butang mencetuskan permintaan Ajax untuk memuatkan senarai produk.

Untuk meningkatkan keselamatan Ajax, terdapat beberapa kaedah: Perlindungan CSRF: menjana token dan menghantarnya kepada pelanggan, menambahnya ke bahagian pelayan dalam permintaan untuk pengesahan. Perlindungan XSS: Gunakan htmlspecialchars() untuk menapis input bagi mengelakkan suntikan skrip berniat jahat. Pengepala Kandungan-Keselamatan-Dasar: Hadkan pemuatan sumber berniat jahat dan nyatakan sumber dari mana skrip dan helaian gaya dibenarkan untuk dimuatkan. Sahkan input sisi pelayan: Sahkan input yang diterima daripada permintaan Ajax untuk menghalang penyerang daripada mengeksploitasi kelemahan input. Gunakan perpustakaan Ajax yang selamat: Manfaatkan modul perlindungan CSRF automatik yang disediakan oleh perpustakaan seperti jQuery.

Ajax bukanlah versi khusus, tetapi teknologi yang menggunakan koleksi teknologi untuk memuatkan dan mengemas kini kandungan halaman web secara tidak segerak. Ajax tidak mempunyai nombor versi tertentu, tetapi terdapat beberapa variasi atau sambungan ajax: 1. jQuery AJAX 2. Axios 4. JSONP 5. XMLHttpRequest 7. Server; -Acara Dihantar; 8, GraphQL, dsb.
