1
我想知道是否有人能告诉我这段代码有什么问题,因为它不起作用,它也不会给我任何错误。在Coldfusion的HREF标签上使用Onclick
通过此代码,我试图访问每次有人按下链接时更新数据库表的组件。
<cfajaxproxy bind="url:http://www.example.com/admin/CRM/linktracking.cfc" />
<cfscript>
SSLtype = (CGI.HTTPS EQ 'off')?'http://':'https://';
</cfscript>
<cfset domainname = CGI.SERVER_NAME>
<cfset domainURL = SSLtype&CGI.SERVER_NAME&CGI.SCRIPT_NAME&'?'&CGI.QUERY_STRING>
<script>
function insertTracking(href) {
var instance = new ajaxjsclass();
instance.setCallbackHandler();
<cfoutput>
instance.insertTrack(href,'#surveymain.contactid#','#domainname#','#domainURL#');
</cfoutput>
}
</script>
这是我试图访问的组件。
<cfcomponent>
<cffunction name="insertTrack" access="remote" returntype="void" >
<cfargument name="clickedURL" required="yes">
<cfargument name="contactid" required="yes">
<cfargument name="domainName" required="yes">
<cfargument name="domainURL" required="yes">
<cfquery name="q_inserttrack" datasource="dpsigweb">
update survey_tracking
set surveystarted = <cfqueryparam value="#now()#" cfsqltype="CF_SQL_TIMESTAMP">
where contactid= '#contactid#'
</cfquery>
<cfif ARGUMENTS.contactid NEQ ''>
<cfscript>
additionalInfo = '<b>Clicked URL</b> - <i>#ARGUMENTS.clickedURL#</i><br><br><b>From Site</b> - <i>#ARGUMENTS.domainURL#</i>';
gaCFC = CreateObject("component","mod_sigweb.components.guestaccount");
gaCFC.AddCorrespondenceCurDoctorProcedureRemote(
functionPassword = 'password',
contactid = '#ARGUMENTS.contactid#',
theMessage = additionalInfo,
statustype = 'Survey Started',
contactresult ='Survey Started'
);
</cfscript>
</cfif>
</cffunction>
</cfcomponent>
这是我想从进入功能:
<a href="http://dev.example.com/surveys/survey.cfm?id=#id#&contactid=#contactid#&doctorid=#doctorid#" onClick="insertTracking(this.href)" >
我怀疑我的<cfajaxproxy>
标签可能有语法错误,但是当我按我没有得到任何的联系错误。
更改我的cfajaxproxy
这个
<cfajaxproxy cfc="linktracking" jsclassname="ajaxjsclass" />
,但仍是功能似乎并没有工作。我甚至将组件和cfm文件移动到同一个文件夹中,但它仍然不起作用。
编辑: 我忘了提及我在电子邮件模板中发送此代码。我不知道这是否有任何问题。我创建了一个测试页,我在本地测试,我的代码工作正常。如果有什么我需要改变,因为请让我知道
你应该在你的函数中实现var作用域。也可以在SQL的WHERE部分使用cfqueryparam。 – duncan
我使用了cfqueryparam,但为了排除可能的错误,我把它关闭了。我会研究var范围,谢谢 – Geo
你看到ajax调用发生了吗?在Firefox中使用FireBug或在Chrome中使用JavaScript控制台,您至少应该看看是否有请求。 –