Applet与JavaScript通讯,将Applet的结果在页面显示

将Applet的Vector解析后,生成网页,以命令树形式展现出来,功能已实现,但是每次触发该功能前必须要先刷新该页面

private void putResult(Vector result)
 {
  JSObject win = JSObject.getWindow(this);
  
  win.eval("parent.treeFrame.document.write('<table width=/"100%/" height=/"100%/" border=/"1/" cellpadding=/"0/" cellspacing=/"0/" class=/"lineright/">   ')");
  win.eval("parent.treeFrame.document.write('  <tr> <td height=/"13/" valign=/"top/"> <br>  ')");
  win.eval("parent.treeFrame.document.write(' <script language=/"JavaScript/" src=/"tree.js/"></script> <script language=/"JavaScript/"> ')");
  win.eval("parent.treeFrame.document.write('foldersTree = gFld(/"结果/", /"/");')");
  for(int i=0;i<result.size();i++)
  {
   String[] oneObj=(String[])result.get(i);
   win.eval("parent.treeFrame.document.write(' "+ "aux" + i +" = insFld(foldersTree, gFld(/""+oneObj[0]+"/"));')");
   if(oneObj[1]!=null && oneObj[1].length()!=0)
   {
    win.eval("parent.treeFrame.document.write(' insDoc("+ "aux" + i +", gLnk(0, /""+"语言属性:"+oneObj[1]+"/", /"/" )); ')");
   }
   if(oneObj[2]!=null && oneObj[2].length()!=0)
   {
    String attr[]=oneObj[2].split(";");
    for(int j=0;j<attr.length;j++)
    {
     int pos=attr[j].indexOf(":");
     win.eval("parent.treeFrame.document.write('"+ "aux"+j+" = insFld("+ "aux" + i +", gFld(/""+attr[j].substring(0,pos)+"/"));')");
     win.eval("parent.treeFrame.document.write(' insDoc("+ "aux"+j+",gLnk(0, /""+attr[j].substring(pos+1)+"/", /"/" ));')");
     
    }
   }
   
  }
  win.eval("parent.treeFrame.document.write(' initializeDocument();')");
  
  win.eval("parent.treeFrame.document.write(' </script> </td> </tr> </table>  ')");
  
 }

tree.js 能容如下:

function Folder(folderDescription, hreference) //constructor
{
  //constant data
  this.desc = folderDescription
  this.hreference = hreference
  this.id = -1  
  this.navObj = 0 
  this.iconImg = 0 
  this.nodeImg = 0 
  this.isLastNode = 0
 
  //dynamic data
  this.isOpen = true
  this.iconSrc = "ftv2folderopen.gif"  
  this.children = new Array
  this.nChildren = 0
 
  //methods
  this.initialize = initializeFolder
  this.setState = setStateFolder
  this.addChild = addChild
  this.createIndex = createEntryIndex
  this.hide = hideFolder
  this.display = display
  this.renderOb = drawFolder
  this.totalHeight = totalHeight
  this.subEntries = folderSubEntries
  this.outputLink = outputFolderLink
}
 
function setStateFolder(isOpen)
{
  var subEntries
  var totalHeight
  var fIt = 0
  var i=0
 
  if (isOpen == this.isOpen)
    return
 
  if (browserVersion == 2) 
  {
    totalHeight = 0
    for (i=0; i < this.nChildren; i++)
      totalHeight = totalHeight + this.children[i].navObj.clip.height
      subEntries = this.subEntries()
    if (this.isOpen)
      totalHeight = 0 - totalHeight
    for (fIt = this.id + subEntries + 1; fIt < nEntries; fIt++)
      indexOfEntries[fIt].navObj.moveBy(0, totalHeight)
  } 
  this.isOpen = isOpen
  propagateChangesInState(this)
}
 
function propagateChangesInState(folder)
{  
  var i=0
 
  if (folder.isOpen)
  {
    if (folder.nodeImg)
      if (folder.isLastNode)
        folder.nodeImg.src = "ftv2mlastnode.gif"
      else
   folder.nodeImg.src = "ftv2mnode.gif"
    folder.iconImg.src = "ftv2folderopen.gif"
    for (i=0; i<folder.nChildren; i++)
      folder.children[i].display()
  }
  else
  {
    if (folder.nodeImg)
      if (folder.isLastNode)
        folder.nodeImg.src = "ftv2plastnode.gif"
      else
   folder.nodeImg.src = "ftv2pnode.gif"
    folder.iconImg.src = "ftv2folderclosed.gif"
    for (i=0; i<folder.nChildren; i++)
      folder.children[i].hide()
  } 
}
 
function hideFolder()
{
  if (browserVersion == 1) {
    if (this.navObj.style.display == "none")
      return
    this.navObj.style.display = "none"
  } else {
    if (this.navObj.visibility == "hiden")
      return
    this.navObj.visibility = "hiden"
  }
  
  this.setState(0)
}
 
function initializeFolder(level, lastNode, leftSide)
{
var j=0
var i=0
var numberOfFolders
var numberOfDocs
var nc
     
  nc = this.nChildren
  
  this.createIndex()
 
  var auxEv = ""
 
  if (browserVersion > 0)
    auxEv = "<a href='javascript:clickOnNode("+this.id+")'>"
  else
    auxEv = "<a>"
 
  if (level>0)
    if (lastNode) //the last 'brother' in the children array
    {
      this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' src='ftv2mlastnode.gif' width=16 height=22 border=0></a>")
      leftSide = leftSide + "<img src='ftv2blank.gif' width=16 height=22>" 
      this.isLastNode = 1
    }
    else
    {
      this.renderOb(leftSide + auxEv + "<img name='nodeIcon" + this.id + "' src='ftv2mnode.gif' width=16 height=22 border=0></a>")
      leftSide = leftSide + "<img src='ftv2vertline.gif' width=16 height=22>"
      this.isLastNode = 0
    }
  else
    this.renderOb("")
  
  if (nc > 0)
  {
    level = level + 1
    for (i=0 ; i < this.nChildren; i++) 
    {
      if (i == this.nChildren-1)
        this.children[i].initialize(level, 1, leftSide)
      else
        this.children[i].initialize(level, 0, leftSide)
      }
  }
}
 
function drawFolder(leftSide)
{
  if (browserVersion == 2) {
    if (!doc.yPos)
      doc.yPos=8
    doc.write("<layer id='folder" + this.id + "' top=" + doc.yPos + " visibility=hiden>")
  }
  
  doc.write("<table ")
  if (browserVersion == 1)
    doc.write(" id='folder" + this.id + "' style='position:block;' ")
  doc.write(" border=0 cellspacing=0 cellpadding=0>")
  doc.write("<tr><td>")
  doc.write(leftSide)
  this.outputLink()
  doc.write("<img name='folderIcon" + this.id + "' ")
  doc.write("src='" + this.iconSrc+"' border=0></a>")
  doc.write("</td><td valign=middle nowrap>")
  if (USETEXTLINKS)
  {
    this.outputLink()
    doc.write(this.desc + "</a>")
  }
  else
    doc.write(this.desc)
  doc.write("</td>") 
  doc.write("</table>")
  
  if (browserVersion == 2) {
    doc.write("</layer>")
  }
 
  if (browserVersion == 1) {
    this.navObj = doc.all["folder"+this.id]
    this.iconImg = doc.all["folderIcon"+this.id]
    this.nodeImg = doc.all["nodeIcon"+this.id]
  } else if (browserVersion == 2) {
    this.navObj = doc.layers["folder"+this.id]
    this.iconImg = this.navObj.document.images["folderIcon"+this.id]
    this.nodeImg = this.navObj.document.images["nodeIcon"+this.id]
    doc.yPos=doc.yPos+this.navObj.clip.height
  }
}
 
function outputFolderLink()
{
  if (this.hreference)
  {
    doc.write("<a href='" + this.hreference + "' TARGET=mainFrame ")
    if (browserVersion > 0)
      doc.write("onClick='javascript:clickOnFolder("+this.id+")'")
    doc.write(">")
  }
  else
    doc.write("<a>")
//  doc.write("<a href='javascript:clickOnFolder("+this.id+")'>")  
}
 
function addChild(childNode)
{
  this.children[this.nChildren] = childNode
  this.nChildren++
  return childNode
}
 
function folderSubEntries()
{
  var i = 0
  var se = this.nChildren
 
  for (i=0; i < this.nChildren; i++){
    if (this.children[i].children) //is a folder
      se = se + this.children[i].subEntries()
  }
 
  return se
}
 
 
// Definition of class Item (a document or link inside a Folder)
// *************************************************************
 
function Item(itemDescription, itemLink) // Constructor
{
  // constant data
  this.desc = itemDescription
  this.link = itemLink
  this.id = -1 //initialized in initalize()
  this.navObj = 0 //initialized in render()
  this.iconImg = 0 //initialized in render()
  this.iconSrc = "ftv2doc.gif"
 
  // methods
  this.initialize = initializeItem
  this.createIndex = createEntryIndex
  this.hide = hideItem
  this.display = display
  this.renderOb = drawItem
  this.totalHeight = totalHeight
}
 
function hideItem()
{
  if (browserVersion == 1) {
    if (this.navObj.style.display == "none")
      return
    this.navObj.style.display = "none"
  } else {
    if (this.navObj.visibility == "hiden")
      return
    this.navObj.visibility = "hiden"
  }    
}
 
function initializeItem(level, lastNode, leftSide)

  this.createIndex()
 
  if (level>0)
    if (lastNode) //the last 'brother' in the children array
    {
      this.renderOb(leftSide + "<img src='ftv2lastnode.gif' width=16 height=22>")
      leftSide = leftSide + "<img src='ftv2blank.gif' width=16 height=22>" 
    }
    else
    {
      this.renderOb(leftSide + "<img src='ftv2node.gif' width=16 height=22>")
      leftSide = leftSide + "<img src='ftv2vertline.gif' width=16 height=22>"
    }
  else
    this.renderOb("")  
}
 
function drawItem(leftSide)
{
  if (browserVersion == 2)
    doc.write("<layer id='item" + this.id + "' top=" + doc.yPos + " visibility=hiden>")
    
  doc.write("<table ")
  if (browserVersion == 1)
    doc.write(" id='item" + this.id + "' style='position:block;' ")
  doc.write(" border=0 cellspacing=0 cellpadding=0>")
  doc.write("<tr><td>")
  doc.write(leftSide)
  doc.write("<a href=" + this.link + ">")
  doc.write("<img id='itemIcon"+this.id+"' ")
  doc.write("src='"+this.iconSrc+"' border=0>")
  doc.write("</a>")
  doc.write("</td><td valign=middle nowrap>")
  if (USETEXTLINKS)
    doc.write("<a href=" + this.link + ">" + this.desc + "</a>")
  else
    doc.write(this.desc)
  doc.write("</table>")
  
  if (browserVersion == 2)
    doc.write("</layer>")
 
  if (browserVersion == 1) {
    this.navObj = doc.all["item"+this.id]
    this.iconImg = doc.all["itemIcon"+this.id]
  } else if (browserVersion == 2) {
    this.navObj = doc.layers["item"+this.id]
    this.iconImg = this.navObj.document.images["itemIcon"+this.id]
    doc.yPos=doc.yPos+this.navObj.clip.height
  }
}
 
 
// Methods common to both objects (pseudo-inheritance)
// ********************************************************
 
function display()
{
  if (browserVersion == 1)
    this.navObj.style.display = "block"
  else
    this.navObj.visibility = "show"
}
 
function createEntryIndex()
{
  this.id = nEntries
  indexOfEntries[nEntries] = this
  nEntries++
}
 
// total height of subEntries open
function totalHeight() //used with browserVersion == 2
{
  var h = this.navObj.clip.height
  var i = 0
  
  if (this.isOpen) //is a folder and _is_ open
    for (i=0 ; i < this.nChildren; i++) 
      h = h + this.children[i].totalHeight()
 
  return h
}
 
 
// Events
// *********************************************************
 
function clickOnFolder(folderId)
{
  var clicked = indexOfEntries[folderId]
 
  if (!clicked.isOpen)
    clickOnNode(folderId)
 
  return 
 
  if (clicked.isSelected)
    return
}
 
function clickOnNode(folderId)
{
  var clickedFolder = 0
  var state = 0
 
  clickedFolder = indexOfEntries[folderId]
  state = clickedFolder.isOpen
 
  clickedFolder.setState(!state) //open<->close 
}
 
function initializeDocument()
{
  if (doc.all)
    browserVersion = 1 //IE4  
  else
    if (doc.layers)
      browserVersion = 2 //NS4
    else
      browserVersion = 0 //other
 
  foldersTree.initialize(0, 1, "")
  foldersTree.display()
 
  if (browserVersion > 0)
  {
    doc.write("<layer top="+indexOfEntries[nEntries-1].navObj.top+">&nbsp;</layer>")
 
    // close the whole tree
    clickOnNode(0)
    // open the root folder
    clickOnNode(0)
  }
}
 
// Auxiliary Functions for Folder-Treee backward compatibility
// *********************************************************
 
function gFld(description, hreference)
{
  description="<font style=font-size:9pt; font-color: #00ff00;background-color:#ccff99>" + description
  folder = new Folder(description, hreference)
  return folder
}
 
function gLnk(target, description, linkData)
{
  description="<font style=font-size:9pt; font-color: #0000ff;background-color:#ccff99>" + description
  fullLink = ""
 
  if (target==0)
  {
    fullLink = "'"+linkData+"' target=mainFrame"
  }
  else
  {
    if (target==1)
       fullLink = "'http://"+linkData+"' target=_top"
    else
       fullLink = "'http://"+linkData+"' target=mainFrame"
  }
 
  linkItem = new Item(description, fullLink)  
  return linkItem
}
 
function insFld(parentFolder, childFolder)
{
  return parentFolder.addChild(childFolder)
}
 
function insDoc(parentFolder, document)
{
  parentFolder.addChild(document)
}
 
// Global variables
// ****************
 
USETEXTLINKS = 1
indexOfEntries = new Array
nEntries = 0
doc = document
browserVersion = 0
selectedFolder=0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值