两个HTML页面如何传递数据?

两个HTML页面如何传递数据?,第1张

一通过表单简单的传输数据,利用js代码接收传递的数据,注意method属性要设为get。
<form id="form" action="datahtml" method="get"></form>//action的值是你的目的html
在你的目的html中可通过url接收传递的数据,并将数据保存在一个对象中。
<script type="text/javascript" charset="utf-8">
windowonload = function() {
var url = windowlocationsearch;//locationsearch是从当前URL的号开始的字符串
consolelog(url);
var Request = new Object();
if (urlindexOf('') != -1) {
var a = '';
var str = urlsubstr(1)  //去掉号
strs = strsplit('&');
for (var i = 0; i < strslength; i++) {
a = strs[i]split('=')[0];
Request[a] = decodeURI(strs[i]split('=')[1]);//解码,生成获取信息的对象
consolelog(Request[a]);
}
}
consolelog(Request);
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
注意这种方式传递中文数据需要用decodeURIComponent()或decodeURL()函数解码,unescape()现在似乎已经淘汰了。
然后利用documentwrite()或innerHTML等方法或函数将数据显示在网页上。此种方法适合自己平时写JS的小练习,此种方法无法将数据保存下来。
2使用Cookie传递参数
下面是简单的实例,a页面保存Cookie,b页面读取。
ahtml
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>a</title>
<script type="text/javascript">
/
@param {string} cookieName Cookie名称
@param {string} cookieValue Cookie值
/
function SetCookie(cookieName,cookieValue) {
/设置Cookie值/
documentcookie = cookieName + "=" + escape(cookieValue)
}
function login() {
var username = $("user")value;
if(usernamelength>0 && username) {
SetCookie("username", username);
/跳转到bhtml页面/
documentlocation = "bhtml";
}
}
function $(id) {
return documentgetElementById(id);
}
</script>
</head>
<body>
<div id="main">
<div><span>请输入你的名字</span><input type="text" id="user" /></div>
<div>
<input type="button" onclick="login()" value="提交" />
</div>
</div>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
bhtml
<html>
<head>
<meta charset="UTF-8">
<title>b</title>
<script type="text/javascript">
/
读取指定的Cookie值
@param {string} cookieName Cookie名称
/
function ReadCookie(cookie_name){
//判断是否存在cookie
if (documentcookielength > 0){
//查询cookie开始部分
cookie_start = documentcookieindexOf(cookie_name + "=")
//如果存在
if (cookie_start != -1){
//计算结束部分
cookie_start = cookie_start + cookie_namelength + 1
cookie_end = documentcookieindexOf(";", cookie_start)
//如果已经是最后一个cookie值,则取cookie长度
if (cookie_end == -1) {
cookie_end = documentcookielength
}
//获取cookie值,unescape对特殊字符解密
return unescape(documentcookiesubstring(cookie_start,cookie_end))
}
}
//其它情况返回空
return ""
}
function $(id) {
return documentgetElementById(id);
}
function init() {
var username = ReadCookie("username");
if(username && usernamelength>0) {
$("msg")innerHTML = "<h1>欢迎光临," + username + "!</h1>";
} else {
$("msg")innerHTML = "<a href='ahtm'>请录入名字</a>";
}
}
</script>
</head>
<body onload="init()">
<div id="msg"></div>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
此种方法也是适合自己平时写JS的小练习,此种方法无法将数据保存下来。
3通过web服务器利用前后端交互
前后端交互又可分为表单交互和url参数交互。表单交互是指在HTML中创建一个表单,用户填写表单后提交给服务器,服务器收到表单后返回处理结果。其大致构成如下:
URL参数经常用于浏览器向服务器提交一些请求信息。其流程图大致如下:
例如利用nodejs与json文件相连接,实现对本地json数据的增删改查,在不同网页间传递数据。
————————————————
版权声明:本文为CSDN博主「想躺」的原创文章,遵循CC 40 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:>function UrlSearch() 
{
   var name,value; 
   var str=locationhref; //取得整个地址栏
   var num=strindexOf("") 
   str=strsubstr(num+1); //取得所有参数   stringvarsubstr(start [, length ]
   var arr=strsplit("&"); //各个参数放到数组里
   for(var i=0;i < arrlength;i++){ 
    num=arr[i]indexOf("="); 
    if(num>0){ 
     name=arr[i]substring(0,num);
     value=arr[i]substr(num+1);
     this[name]=value;
     } 
    } 

var Request=new UrlSearch(); //实例化
var name=Requestname;

望采纳。

html文件中私用JavaScript将url的汉子转为为GBK编码,主要是通过改变GBK的编码方式来实现,代码如下:

function urlencode(str, charset, callback) {
    //创建form通过accept-charset做encode
    var form = documentcreateElement('form');
    formmethod = 'get';
    formstyledisplay = 'none';
    formacceptCharset = charset;
    var input = documentcreateElement('input');
    inputtype = 'hidden';
    inputname = 'str';
    inputvalue = str;
    formappendChild(input);
    formtarget = '_urlEncode_iframe_';
    documentbodyappendChild(form);
    //隐藏iframe截获提交的字符串
    if (!window['_urlEncode_iframe_']) {
        var iframe = documentcreateElement('iframe');
        //iframename = '_urlEncode_iframe_';
        iframesetAttribute('name', '_urlEncode_iframe_');
        iframestyledisplay = 'none';
        iframewidth = "0";
        iframeheight = "0";
        iframescrolling = "no";
        iframeallowtransparency = "true";
        iframeframeborder = "0";
        iframesrc = 'about:blank';
        documentbodyappendChild(iframe);
    }
    //
    window_urlEncode_iframe_callback = callback;
    //设置回调编码页面的地址,这里需要用户修改
    formaction = 'getEncodeStrhtml';
    formsubmit();
    setTimeout(function() {
        formparentNoderemoveChild(form);
        iframeparentNoderemoveChild(iframe);
    }, 500)
}

<php
$str= '<a href="itemphpmarc_no=0000484196">1111111111111111</a>';
preg_match('/<a href="()">()<\/a>/',$str,$t);
print_r($t);


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/10555788.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-09
下一篇 2023-05-09

发表评论

登录后才能评论

评论列表(0条)

保存