有人可以用一些逻辑来帮助我吗?

时间:2011-11-05 13:37:45

标签: javascript xml dom logic

我无法发展这种逻辑,有人可以帮我解决这个问题吗?

我有一些很大的逻辑可以让我坚持下去。

我有一个完全动态的XML - 它的Detail节点可能会增加和减少数量 细节节点的子节点数量也可以增加和减少。

<?xml version="1.0" encoding="utf-8" ?>
<body>
  <detail>
    <FirstName>t1 </FirstName>
    <LastName>t2</LastName>
    <Company>t3</Company>
    <Country>t4</Country>
    <Proviance>MP</Proviance>
  </detail>

  <detail>
    <FirstName>t5 </FirstName>
    <LastName>t6</LastName>
    <Company>t7</Company>
    <Country>t8</Country>
    <Proviance>t9</Proviance>
  </detail>

  <detail>
    <FirstName>t10 </FirstName>
    <LastName>t11</LastName>
    <Company>t12</Company>
    <Country>t13</Country>
    <Proviance>t14</Proviance>
  </detail>

</body>

我读了这样的XML:

 xmlhttp = new XMLHttpRequest();
        xmlhttp.open("GET", "/TinyEditor/PreviewBody.xml", true);
        xmlhttp.send();
        xmlDoc = xmlhttp.responseXML;

现在

每当我像这样读取DOM中的HTML内容时,每次都会有所不同:

      var x = tinyMCEPopup.editor.getContent().toString();
        alert(x);

the x gets the value like this (x can be different at different times) 

<p>Headline Dear <br /> <br /> <img src="Images/Untitled.png" alt="" /> <br /> <br />Dear <strong>FirstName&nbsp; <strong> LastName</strong></strong></p>
<p><strong><br /></strong></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; I am from company <strong> Company</strong> that is located in <strong> Country</strong>,&nbsp; <strong> Proviance</strong>, <strong> City.</strong></p>
<p><strong><br /></strong></p>
<p>Thanks</p>
<p><strong>FirstName</strong> <strong> LastName</strong> </p>
<p><strong><br /></strong></p>
<p>&nbsp;</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </p>

现在我想在此HTML中搜索XML中的每个详细信息元素,并希望用XML中的元素值替换HTML(FirstName,LastName)中的文本 每个细节节点的节点 之后,我将格式化的HTML内容重写为DOM。 这是我无法发展的逻辑,有人可以帮我解决这个问题吗?


我的努力:

<xsl:for-each select="Home/menu">
    <xsl:variable name="i"><xsl:value-of select="1+position()" /></xsl:variable>
    <script language="javascript">
        var id = '<xsl:value-of select="$i"/>';
        var firstname = '<xsl:value-of select="firstname"/>';
        var lastrname = '<xsl:value-of select="lastrname"/>';
        var firstname = '<xsl:value-of select="firstname"/>';
        var lastrname = '<xsl:value-of select="lastrname"/>';
        var firstname = '<xsl:value-of select="firstname"/>';
        var lastrname = '<xsl:value-of select="lastrname"/>';
        $('#CurrProg-'+id).html(functionname('FirstName',firstname));
        $('#CurrProg-'+id).html(functionname('LastName',firstname));
        $('#CurrProg-'+id).html(functionname('tagname',firstname));
        $('#CurrProg-'+id).html(functionname('tagname',firstname));
        $('#CurrProg-'+id).html(functionname('tagname',firstname));
        $('#CurrProg-'+id).html(functionname('tagname',firstname));
    </script>
</xsl:for-each>

和功能

    

    $(document).ready(function () {

        /* load all xsl and xml file */

        xmlDoc = $.xsl.load('XML/PreviewBody.xml');
        xslHome = $.xsl.load('XSL/Preview.xsl');

        $('#Page_Content').getTransform(
    xslHome,
    xmlDoc
);

    });

 function textReplace(actualtext, replacementtext) {
        var actualtext = new RegExp(actualtext, 'ig');
        document.getElementById('content').innerHTML = x.replace(actualtext, replacementtext);

    }

但它不适用于动态XML,我必须提前修复节点...我想在运行时制作它。

2 个答案:

答案 0 :(得分:4)

我更愿意为此目的使用JQuery。它非常便于执行此类任务,您无需为每个浏览器制作代码。

http://www.vagrantradio.com/2009/10/how-to-parse-xml-using-jquery-and-ajax.html

答案 1 :(得分:0)

您应该使用xslt生成内容而不是脚本

如果你仍然想做什么,我可以重新推荐以下内容:使用{FirstName}代替FirstName,因为你可以更好地找到它(FirstName不可能出现替换)和顺便说一句放弃你的xslt并用dom

循环xml

我也不认为你正在使用new RegExp()正确的检查手册

b.t.w。你说任何细节elelemnt但不是拥有你必须选择1个细节元素并循环其兄弟姐妹

这是js中的替换代码(不知道jquery(对不起))

function textReplace(actualtext, replacementtext) {
  document.getElementById('content').innerHTML = document.getElementById('content').innerHTML.replace(actualtext,replacementtext);
}