这两天客户的需求不能定下来,做闲人好长时间了,不如来整理下最近碰到的一些个小麻烦。

正题:

场景一、

最近在开发的过程中使用到了百度的富客户端文本编辑器(ueditor)---这是一款功能很强大的文本编辑器,

现在需求:当在这个页面打开以后需要把用户上次编辑的信息写回到此文本编辑器中去,这里使用的方法是ueditor给定的方法。同时使用iframe对此编辑器进行了页面嵌套的显示。

   //将html代码展示到编辑器中。
function insertHtml(value) {
setContent("");
UE.getEditor('newsContent').execCommand('insertHtml', value)
}
//获得编辑器的HTML代码。
function getContent() {
return UE.getEditor('newsContent').getContent();
}
//设置编辑器内容,非html形式用于设置编辑器为null,也可以使用insertHtml("");
function setContent(isAppendTo) {
UE.getEditor('newsContent').setContent(isAppendTo);
}

获取与写入编辑器内容方法

当我在单前页面直接使用setContent(data)进行数据写入的时候发现当页面刷新完成以后并不是每一次都能成功的写入到文本编辑器中去,那么问题来了,为什么不会每次都能成功,经过调试发现没有报出任何错误。。。。试了一些办法,后来发现当页面加载的时候并不能直接使用iframe子页面中所定义的方法,需要在当前页面全部加载完成以后才可以调用相关的方法,在此处写入数据的时候加上setTimeout完美解决问题

 setTimeout(function(){
eWebEditor.setContent(content);
},1000);

解决代码

场景二、

现在需求:我在父页面通过jquery插件colorbox打开了一个子页面(A),在这个页面上进行操作的时候因为不想继续打开新的子页面所以我在这里用的是parent.$.colorbox从父页面直接打开了一个新的colorbox(B)来替换了当前的这个子页面,当在B页面操作完成以后我需要通过在父页面设置的一个方法转换到原来由父页面打开的子页面A去。

这时我可以通用过parent获取到父页面的全部信息了,也可以实现了基本的功能,但是在浏览时下面会报出一个 SCRIPT5007: 缺少对象 的错误,代码书写的正确,A页面正常使用,B页面也能正常工作,只有在当我在B页面通过父页面方法跳转到A页面时浏览器会报出这个异常,但是可以跳转到B页面的。想了好长时间的思路也试过了好多方法都不能解决这个问题,后来发现当我发出事件时如果有停顿,也就是alert的提示框没有迅速关闭时这个错误就不会发生了,这是我就想到了setTimeout,一用果然没有再出现这种错误了。

现在还在纠结着个问题到底是为什么,,,,,

setTimeout(function(){
parent.$("#btn_upd").click();
},500);

解决代码

其实在父页面打开另外一个也页面的话当前的这个页面应该是关闭了的吧。还是说也是存在的只是显示被覆盖了,设置完setTimeout加载完成后就可以调用方法了?

关于页面刷新或者调用方法事获取不到元素信息或者出现缺少对象错误的换位思考setTimeout的使用的更多相关文章

  1. html-javascript前端页面刷新重载的方法汇总

    记得我在兴安得力实习要转正的时候,我领导象征性的给我出了一套测试题目,里面就有js闭包和页面刷新等题目.今天把很久之前的测试题目之一,js页面刷新的方法以及页面自动刷新跳转和返回上一页和下一页等方法总 ...

  2. ASP.NET页面刷新的实现方法总结

    先看看ASP.NET页面刷新的实现方法: 第一: private void Button1_Click( object sender, System.EventArgs e ) { Response. ...

  3. 获取APP的元素信息和Activity

    一.获取元素信息 (1)第一种方法是,在windows命令行中输入uiautomatorviewer.bat(前提是已配置好Android SDK环境),按回车键:等待几秒后会打开UI Automat ...

  4. C#调用页面中的窗体中的方法,获取窗体的元素。

    页面中的窗体 <div class="div_width" style="width: 100%; height: 95%;"> <ifram ...

  5. javascript页面刷新的一些方法

    在使用js刷新页面的时候,有时会遇到表单的重复提交问题 这时就需要一些强制刷新的办法,从网上大概搜了一下,js的刷新方法大致有以下几种, 刷新页面,不提示重新发送: window.location.r ...

  6. jQuery中,子页面与父页面之间的调用方法

    在jQuery中, 子页面查找父页面的元素 parent.$("#元素Id") 父页面调用子页面的元素 $("#子页面iframe的Id").contents( ...

  7. URL跨项目调用方法,获取返回的json值,并解析

    package com.mshc.util; import java.io.BufferedReader; import java.io.IOException; import java.io.Inp ...

  8. 微信小程序调用微信登陆获取openid及用户信息 java做为服务端

    转载的文章,很不错 https://blog.csdn.net/weilai_zhilu/article/details/77932630

  9. java基础:方法的定义和调用详细介绍,方法同时获取数组最大值和最小值,比较两个数组,数组交换最大最小值,附练习案列

    1. 方法概述 1.1 方法的概念 方法(method)是将具有独立功能的代码块组织成为一个整体,使其具有特殊功能的代码集 注意: 方法必须先创建才可以使用,该过程成为方法定义 方法创建后并不是直接可 ...

随机推荐

  1. php如何实现上传图片文件,并替换

    首先建立两个文件: change.html 和 change.php change.html 文件的表单代码如下: <html><head> <title>chan ...

  2. 3月25日html(六) Javascrip

                             第1部分 JavaScript简介 1.JavaScript它是个什么东西? 它是个脚本语言,需要有宿主文件,他的宿主文件是html文件. 2.它与J ...

  3. table-cell的手机应用场景

    前言 最近在前端观察看见了这篇老文章,看见了元素居中的5种办法,其中提到了display:table-cell这个css显示的新属性,按照当时的浏览器市场来说想必兼容性会是糟糕的一比,但是现在这坛老酒 ...

  4. AngularJS自定义表单验证器

    <!doctype html> <html ng-app="myApp"> <head> <script src="G:\\So ...

  5. zookeeper笔记--配置以及和spark hbase结合使用

    Spark集群基于ZooKeeper的搭建:http://www.dataguru.cn/thread-333245-1-1.html Spark需要修改的地方: 进入spark的配置目录,参照下面代 ...

  6. UITableView常用属性和方法 - 永不退缩的小白菜

    UITableView常用属性和方法 - 永不退缩的小白菜 时间 2014-05-27 01:21:00  博客园精华区原文  http://www.cnblogs.com/zhaofucheng11 ...

  7. JQuery的插件

    最近需要修改ftl文件,使用一般的freemarker插件不能有效处理里边的部分JQuery内容,所以特地下载了一个Spket插件, 地址为 http://www.agpad.com/update 再 ...

  8. 使用Query 进行空值(empty)校验

    效果如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  9. C(m,n)%P

    program1 n!%P(P为质数) 我们发现n! mod P的计算过程是以P为周期的的,举例如下: n = 10, P = 3 n! = 1 * 2 * 3 * 4 * 5 * 6 * 7 * 8 ...

  10. hdu3401:单调队列优化dp

    第一个单调队列优化dp 写了半天,最后初始化搞错了还一直wa.. 题目大意: 炒股,总共 t 天,每天可以买入na[i]股,卖出nb[i]股,价钱分别为pa[i]和pb[i],最大同时拥有p股 且一次 ...