简单的coldfusion传递记录id到JS函数?

时间:2012-02-23 15:10:15

标签: javascript coldfusion cfml

我试图通过cfm页面传递唯一的数据库会话ID但似乎无法使其正常工作。第1页有记录ID,我试图在recordclick()函数中保存numSession并在下一页中传递它,我在查询中使用它,但它不起作用。

下面简要概述了我在做什么:

第1页:

<CFQUERY datasource = "database1" result = "result">
insert into user
set
blah blah
</cfquery>

<html>
<head>   
<title>page1</title>
<script type="text/javascript">
function recordClick(imageid)
{
        document.getElementById("numSend").value =       document.getElementById("numSend").value + imageid;
        document.getElementById("numSession").value = result.generated_key;
}
</script>
</head>

<body>
<FORM action="page2.cfm" method="post">

<img src="1.png" NAME="num1" onclick="recordClick(1)"
    width="100px"
    height="100px"> 
<div name="num1" id="num1"></div>

<input type="hidden" id="numSend" name="numSend" />
<input type ="hidden" id = "numSession" name ="numSession" />
<input type="submit" value="Done" />
</form>

</body>
</html>

--------------------------------------

<cfoutput>
The ID of the row I just inserted was "#numSession#"
</cfoutput>


<CFQUERY datasource = "database1">
update user
set
pin = "#numSend#"
where id= "#numSession#"
</cfquery>

1 个答案:

答案 0 :(得分:5)

ColdFusion在服务器上执行,JavaScript在客户端上执行。你的JS不知道result是什么。

您需要使用ColdFusion's ToScript() function

  

<强>描述

     

创建分配值的JavaScript或ActionScript表达式   ColdFusion变量的一个JavaScript或ActionScript变量。   这个函数可以转换ColdFusion字符串,数字,数组,   结构,以及对JavaScript或ActionScript语法的查询   定义等效变量和值。

以下是一个例子,取自文档:

<cfset thisString="hello world">
<script type="text/javascript" language="JavaScript">
    <cfoutput>
        var #ToScript(thisString, "jsVar")#;
    </cfoutput>
</script>

您的代码(已更正):

function recordClick(imageid)
{
    var <cfoutput>#ToScript(result.generated_key, "generated_key")#;</cfoutput>
    var objNumSend = document.getElementById("numSend");
    objNumSend.value = objNumSend.value + imageid;
    document.getElementById("numSession").value = generated_key;
}