如何实现不刷新页面,只重新加载js文件?

 我来答
cs903016
2017-04-07 · TA获得超过1179个赞
知道小有建树答主
回答量:2599
采纳率:80%
帮助的人:1720万
展开全部

不刷新页面,重新加载js文件的方法有:

  1. 通过js创建script标签,例如

    var script = document.createElement("script");
    script.src = "test.js";
    document.body.appendChild(script);

2.通过ajax实现无刷新加载,ajax的方法可以自己写,也可以引用,以下引用的是jquery的ajax

$.ajax({
    type = "get",
    url : "test.js",
    dataType : "script"
});

总结:如果是自己写js,不引用。建议用第一种,第二种也可以参考。

xinxin欣欣1314
2018-04-05 · TA获得超过5506个赞
知道小有建树答主
回答量:25
采纳率:0%
帮助的人:4406
展开全部

我来还原一下场景:

a.animate({},function(){

b.animabe({})

})

假设你的页面大动画由两个小动画组成,大概是上面的样子。
动画改变的是什么?元素的样式。
element和js是分离的,你重新加载了js,也仅仅是覆盖了原来的变量方法而已,html的样式还是那个样子。
所以要复位画面,需要使用js去改变元素样式,这一步你逃不掉的。

取巧的办法是有的。
我设想你的页面为了兼容性等原因,没有使用css3来参与动画,而是使用动画框架比如jQuery的animate,而这些动画框架一般是通过动态改变标签内部的style来形成动画。
这说明,动画前后,变化的是标签内style属性。
比如从:
<div  id="J_move"></div>
变化为
<div  id="J_move" style="width:100px;"></div>

于是可以通过删除标签内的style属性来恢复,遍历一下所有你动画过的节点:
$elem.attr('style',"");
补充:后来我发现ie67中不能通过setAttribute来设置style,至于jQuery.attr没有试。可以先将jQuery对象转化为DOM对象,然后使用style.cssText='';来清空style。
前提是:动画前,这些元素都没有标签内style属性;动画过程中,你没有动态改变动画元素的className,而且动画元素的style也没有被其它程序修改过。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
BUG集散地
2016-10-17 · TA获得超过1317个赞
知道小有建树答主
回答量:625
采纳率:80%
帮助的人:287万
展开全部
  1. 方法:可以通过js动态创建元素来引入js文件,由createElement来动态创建元素,动态的引入文件;

  2. 思路:首先删除原本的script标签,然后动态添加新的script标签来重新引入。

  3. 具体代码:

<script id="reloadJs" type="text/javascript" src="aaa.js" ></script>
<script type="text/javascript">
var reloadJs = function(id){
    var jsObj = document.getElementById(id);
    var src = jsObj.src;
    delete jsObj;
    //重新加载
    var script = document.createElement('script');
    script.src = src;
    document.body.appendChild(script);
};
</script>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
随便一个明
2017-02-22 · TA获得超过115个赞
知道答主
回答量:36
采纳率:100%
帮助的人:10.6万
展开全部
在js文件里面通过添加script标签的形式加载js文件
比如在页面里面点击一个按钮(或者触发一个事件什么的)就会执行 : 创建script标签,然后修改src,在吧创建出来的script标签添加到HTML里面
你只要吧你需要加载的js文件的路径写在创建出来的script标签的src里面就行了。。。
这样就可以实现页面不加载 只加载js文件
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
黑马程序员
2016-09-13 · 改变中国IT教育,我们正在行动
黑马程序员
黑马程序员为大学毕业后,有理想、有梦想,想从事IT行业的年轻人改变自己的命运。黑马程序员成就IT黑马
向TA提问
展开全部
第一种
var jsElem = document.createElement('script');
jsElem.src='require.min.js';
document.getElementsByTagName('head')[0].appendChild(jsElem);
第二种
$.ajax({
type: "GET",
url: "test.js",
dataType: "script"
});
第二种完美实现
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(18)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式