精华内容
下载资源
问答
  • 前言:一提到页面跳转,最常用的一般就是window.location.href,如果需要带参数,也许可以在后面用?...需求:解决window.location.href参数过长的问题 思路:我们再想想别的解决方案,我们知道post请求是没...

    前言:一提到页面跳转,最常用的一般就是window.location.href,如果需要带参数,也许可以在后面用?拼上,但这样并不安全,而且有个更严重的问题,这样的拼接是有长度限制的,如果达到好几千个字符,比如传个base64???这时你会发现浏览器报错了,直接不能传参了。

    需求:解决window.location.href参数过长的问题

    思路:我们再想想别的解决方案,我们知道post请求是没有参数长度限制的,而且还是比较安全的。post请求的方式第一能想到的肯定是ajax,但是可惜的是ajax好像不能跳转,但是不要忘记还有一种也能设置成post请求的,那就是表单了。那么这样我们就可以试试创建一个隐藏的表单,通过提交表单的方式来跳转。

    方案

    post('******.do',{"username":p1,"userId":p2,"userCode":p3,"imgUrl":imgUrl});
    
    function post(url, params) { 
        // 创建form元素
        var temp_form = document.createElement("form");
        // 设置form属性
        temp_form .action = url;      
        temp_form .target = "_self";
        temp_form .method = "post";      
        temp_form .style.display = "none";
        // 处理需要传递的参数 
        for (var x in params) { 
            var opt = document.createElement("textarea");      
            opt.name = x;      
            opt.value = params[x];      
            temp_form .appendChild(opt);      
        }      
        document.body.appendChild(temp_form);
        // 提交表单      
        temp_form .submit();     
    } 

    可以看到,这里相当于做了一个隐藏的一次性使用的表单,该表单的提交方式是post,这样就完美的解决了参数过长的问题。

    转载于:https://www.cnblogs.com/Kingram/p/10044583.html

    展开全文
  • 需求:解决window.location.href参数过长的问题 思路:我们再想想别的解决方案,我们知道post请求是没有参数长度限制的,而且还是比较安全的。post请求的方式第一能想到的肯定是ajax,但是可惜的是ajax好像不能

    前言:一提到页面跳转,最常用的一般就是window.location.href,如果需要带参数,也许可以在后面用?拼上,但这样并不安全,而且有个更严重的问题,这样的拼接是有长度限制的,如果达到好几千个字符,比如传个base64???这时你会发现浏览器报错了,直接不能传参了。

    需求:解决window.location.href参数过长的问题

    思路:我们再想想别的解决方案,我们知道post请求是没有参数长度限制的,而且还是比较安全的。post请求的方式第一能想到的肯定是ajax,但是可惜的是ajax好像不能跳转,但是不要忘记还有一种也能设置成post请求的,那就是表单了。那么这样我们就可以试试创建一个隐藏的表单,通过提交表单的方式来跳转。

    $("#derive").click(function () {
        var start_time=$('#start_time').val();
        var end_time=$('#end_time').val();
        var orgName=$('#orgName').val();
        var resourceName=$('#resourceName').val();
        var regionName=$('#regionName').val();
        var url = getRootPath()+"/exchangeNum/exportExcel";
        var params ={"start_time":start_time,
            "end_time":end_time,
            "orgName":orgName,
            "resourceName":resourceName,
            "regionName":regionName};
    
        post(url,params);
    
    })
    
    function post(url, params) {
        // 创建form元素
        var temp_form = document.createElement("form");
        // 设置form属性
        temp_form .action = url;
        temp_form .target = "_self";
        temp_form .method = "post";
        temp_form .style.display = "none";
        // 处理需要传递的参数
        for (var x in params) {
            var opt = document.createElement("textarea");
            opt.name = x;
            opt.value = params[x];
            temp_form .appendChild(opt);
        }
        document.body.appendChild(temp_form);
        // 提交表单
        temp_form .submit();
    }

    可以看到,这里相当于做了一个隐藏的一次性使用的表单,该表单的提交方式是post,这样就完美的解决了参数过长的问题

    参考:https://www.cnblogs.com/zzt-lovelinlin/p/11461097.html

    展开全文
  • (1)window.location.href 得到和使用的是完整的url,比如window.location.href="juejin.im”表示的是重新定向,页面跳转 到新的页面。也可以通过window.location.href得到a标签的完整的href,比如如果使用href,...

    (1)window.location.href 得到和使用的是完整的url,比如window.location.href="juejin.im”表示的是重新定向,页面跳转

    到新的页面。也可以通过window.location.href得到a标签的完整的href,比如如果使用href,那么可以得到完整的链接(url)

    (2)window.location.hash

    得到的是锚链接。相比如href,通过window.location.hash并不会跳转到新的链接,只会在当前链接里面

    改变锚链。并且如果有通过window.location.hash得不到完整的链接(URL),仅仅得到#juejin.

    window.location.hash这个属性可以对URL中的井号参数进行修改,基于这个原理,我们可以在不重载页面的前提下创造一天新的访问记录。

    井号作为页面定位符出现在URL中,比如:juejin.im#ads_library,此URL表示在页面https://juejin.im中…

    展开全文
  • window.location....【相当于 按页面刷新按钮】(如果有数据提交的话,会提示是否提交的(是和否选项)) window.location.href=window.location.href; 是定向url提交数据 他们最大区别是 是否有数据提交:...

    https://www.cnblogs.com/linsx/p/6802382.html

     

    window.location.Reload()应该是刷新.【相当于 按页面刷新按钮】

    (如果有数据提交的话,会提示是否提交的(是和否选项))

    window.location.href=window.location.href;
    是定向url提交数据

    他们最大区别是 是否有数据提交:

    前者提交数据的刷新                                                          

    后者没有提交的刷新

    首先介绍两个方法的语法:

    reload 方法,该方法强迫浏览器刷新当前页面。
    语法:location.reload([bForceGet])参数: bForceGet, 可选参数, 默认为 false,从客户端缓存里取当前页。 true, 则以GET 方式,从服务端取最新的页面, 相当于客户端点击 F5("刷新")

    replace 方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,你不能通过“前进”和“后退”来访问已经被替换的URL
    语法:location.replace(URL) 参数: URL

    在实际应用的时候,重新刷新页面的时候,我们通常使用: location.reload() 或者是 history.go(0) 来做。因为这种做法就像是客户端点F5刷新页面,所以页面的method="post"的时候,会出现“网页过期”的提示。那是因为Session的安全保护机制。可以想到: 当调用 location.reload() 方法的时候, aspx页面此时在服务端内存里已经存在, 因此必定是 IsPostback 的。如果有这种应用: 我们需要重新加载该页面,也就是说我们期望页面能够在服务端重新被创建, 我们期望是 Not IsPostback 的。这里,location.replace() 就可以完成此任务。被replace的页面每次都在服务端重新生成。你可以这么写: location.replace(location.href)

    =======================================================
    <a οnclick="javascript:window.location.href=window.location.href;">

    <a οnclick="javascript:window.location.reload();">

    测试效果一样。表单没有提交。

    <input type="submit" οnclick="javascript:window.location.reload();" value="单击" id="btnVCode" />
    <input type="submit" οnclick="javascript:window.location.href=window.location.href;" value="单击" id="btnVCode" />

    都提交数据

     

    window.location.Reload()应该是刷新.(如果有数据提交的话,会提示是否提交的(是和否选项))
    window.location.href=window.location.href; 是定向url提交数据

    最好不要用location.reload(),而用location=location比较好,还有在模式窗口(showModalDialog和showModelessDialog)前者不能用。

     

    reload参数有true和false,比较有意思?

    避免重复提交:

        protected void Repeater1_ItemDataBound(object sender, RepeaterItemEventArgs e)
        {
            if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
            {
                string nr = ((DataRowView)e.Item.DataItem).Row["GZZDS"].ToString();
                string id = ((DataRowView)e.Item.DataItem).Row["RZID"].ToString();
                string rid = ((DataRowView)e.Item.DataItem).Row["RWXH"].ToString();
                string link = "";

                if (nr == "")
                {
                    link = "<a href='#' οnclick=\"selectGuide2('BookDoc.aspx?type=2&Id=" + id + "&rid=" + rid + "&Rnd='+Math.random());location=location;\">选择指导书</a>";
                }
                else
                {
                    string t = (ViewState["State"].ToString() == "Query" || ((DataRowView)e.Item.DataItem).Row["GZZT"].ToString() == "工作结束") ? "false" : "true";
                    string path=((DataRowView)e.Item.DataItem).Row["GZZDSPath"].ToString();               

                    link = "<a href='#' οnclick=\"EditWord('" + path + "'," + t + ")\">" + nr + "</a>";
                }

                ((Literal)e.Item.FindControl("Literal1")).Text = link;
            }
        }

     window.location.Reload()和window.location.href  window.location.Reload()应该是刷新.(如果有数据提交的话,会提示是否提交的(是和否选项))
    window.location.href=window.location.href;
    是定向url提交数据
    是大的区别还是是否提交数据了

    function refresh()
    {
    //刷新页面函数
    //window.focus();刷新窗口
    //document.execCommand("Refresh");刷新窗口
    //self.location.reload();刷新当前窗口
    parent.location.reload();刷新父窗口
    //aaa.location.reload();弹出窗口刷新父窗口
    }   

    使用window.location.replace() or window.location.href(), 来重新加载此页面不出现提示框

     

     

    http://www.cnblogs.com/tearer/archive/2013/03/16/2963438.html

     

    展开全文
  • 在JS中可以用window.location.href = window.location.href来刷新页面(当然还有很多其他的方法),在使用这个方法刷新页面的时候回出现问题,如下: <!--function refresh(){ window.location.href = window....
  • window.location....window.location.href=window.location.href; 是定向url提交数据 location.reload()意思是从服务器端重新载入页面 ;reload 方法,该方法强迫浏览器刷新当前页面 location.reload([bF
  • 使用window.location....解决此问题,应该这样写: window.location.href=window.location.href; window.location.reload; 同理,如果是刷新父窗口,应该这样写: window.opener.location.href=window.opener.locatio
  • 在web开发中经常会遇到页面刷新的系列问题,现在总结如下: 1、js 刷新页面window.location.reload();...2、window.location.href设置或返回完整的 URL。 在js中关于location.href的用法究竟有哪几种,
  • window.location.href后携带参数

    千次阅读 2017-04-27 13:50:00
    window.location.href后可携带参数,但是不安全,虽然在技术上是可以实现的 1.传参:window.location.href = "RecordCare.aspx?id=" +id+"&name="+escape(name); 2. 获取url中"?"符后的字串 var url = ...
  • 获取window.location.href路径参数

    千次阅读 2018-08-20 11:29:00
    function getUrlParams(params){ var urlObj = {}; ...window.location.search){return false;} var urlParams = window.location.search.substring(1); var urlArr = urlParams.split('&...
  • window.location.href跳转传参并接收参数

    千次阅读 2020-07-13 15:13:13
    window.location.href = "buyOil.html?userId="+ res.userId; buyOil.html 这是跳转路径的地址 res.userId是我们传过去的参数,在这里我们模拟res.userId是2,所以就变成了 window.location.href = "buyOil....
  • window.location.href不跳转问题

    千次阅读 2017-08-10 10:50:22
    window.location.href不跳转
  • 首先介绍两个方法的语法: reload 方法,该方法强迫浏览器刷新...语法:location.reload([bForceGet])参数: bForceGet, 可选参数, 默认为 false,从客户端缓存里取当前页。 true, 则以GET 方式,从服
  • window.location.href的target控制

    万次阅读 2017-03-09 11:15:53
    window.location.href的target控制 在使用框架时,经常会对框架子页面进行页面引导的情况,如果只是简单的设置location. href="",会使得整个页面显示在子框架中,导致出现重叠框架。如何解决呢?很简单。只要...
  • window.location.href=webPath+"back/car/generatePdf"+ '?' + $.param({"backPeriodDTO": JSON.stringify(json),"backPeriod": JSON.stringify(json1)})
  • 一、jquery 实现window.location.href向跳转页传递参数 1、跳转页(通过传递带参数的url来实现页面跳转传递参数的目的) if (response.status===10000){ //name 是用户名的变量,pwd 是密码的变量 window.location.href...
  • 1.window.location.href = url+"&name=" + encodeURI(encodeURI(name)) ; name是中文,客户端编码两次,服务器端只需要解码一次 name = java.net.URLDecoder.decode(name, "UTF-8"); 2...
  • window.location.href="URL"; 表示重新定向到新页面,同时刷新打开的这个页面; 例子:window.location.href="http://www.baidu.com"//也可以直接放接口 window.open("URL",'top'); 只是表示打开这个页面,并不...
  • window.location.href 传中文乱码

    千次阅读 2017-07-11 11:09:50
    window.location.href url含中文服务器收到乱码问题解决 中文乱码问题 window.location.href url含中文服务器收到乱码问题解决 (1).页面中先对中文进行编码。 如:window.location.href = url+"&...
  • window.location.href用法

    千次阅读 2017-09-30 14:34:35
    1、参数为java中的变量和js中变量组合 java代码 String username = "";...window.location.href = "XXXXX.jsp?user=&province="+items; window.location.href = "XXXXX.jsp?mediaName=" + mediana
  • 例如 window.location.href ="/xx.jsp?name="+name+"";  这样子则会乱码 改成 window.location.href ="/xx.jsp?name="+ encodeURI(encodeURI(name))+"";  在接受的jsp页面 或者是controller 中进行解码
  • 使用window.location.href和document.referrer

    千次阅读 2017-07-26 17:15:38
    在使用这两者并且想要在其后面加参数时应注意:判断window.location.hrefwindow.location.href中是否包含?,包含拼接&,不包含拼接?。 if(document.referrer.indexOf('?')>-1){ window.loca
  • 想用window.location.href跳转到另外一个界面。但直接传递get方法会暴露数据。  而用ajax或表单提交,有时在执行了方法后,无法跳转到另外的页面。  下面可以实现跳转的效果,却又能够通过post传递方法隐藏数据...
  • window.location.href传递汉字参数

    千次阅读 2017-02-08 16:55:39
    window.location.href = GetPageName() + "?category_id=" + _category_id + "&recommend=" + _recommend + "&word=" + encodeURI(encodeURI(_word)); word是中文,客户端编码两次,服务端解码一次 C#代码: _word =...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 65,505
精华内容 26,202
关键字:

window.location.href参数