JS調用C++


1.注冊C++函數。
//注冊回調函數宏
//根據不同需要支持注冊兩個函數原型,注意CONNECT_JS_CALL_SIMPLE_HANDLER中注冊的函數
//需要提前和HTML調用協調好,參數必須都為字符,負責會引起未知問題
#define CONNECT_JS_CALL_HANDLER(name, func, pContext) do \
{\
if (!CBKCallBackFuncContainer::GetFuncPtr()->NameId(L#name)) \
CBKCallBackFuncContainer::GetFuncPtr()->ConnectJSFuncHandler(L#name, (JSCallbackFunction)&func, FALSE, pContext);\
} while (FALSE);
 
 
CONNECT_JS_CALL_HANDLER(OpenCustomStockDlg, (JSCallbackFunction)&OpenCustomStockDlg, this);
 
2.被調函數聲明。
static int OpenCustomStockDlg(DISPPARAMS* params, VARIANT* retval , void* pContext);
3.被調函數實現。
int CXXWindow::OpenCustomStockDlg(DISPPARAMS* params, VARIANT* retval , void* pContext)
{
CFinancialMainWindow* _pThis = static_cast<CFinancialMainWindow*>(pContext);
ATLASSERT(_pThis);
CString strCur = "0";
if (params->cArgs == 1)
{
strCur = params->rgvarg[0];
}
 
//_pThis->OpenLogingSetDlg(StrToLong(strCur));
CString strPara = _pThis->Get_SignPara();
CustomStockSynchronous dlgCustomStock(strPara);
dlgCustomStock.DoModal();
 
return 0;
}
 
4.html編寫
<HTML>
<HEAD><TITLE>js 按鍵記錄</TITLE>
</HEAD>
<script type="text/javascript">
function $(s){return document.getElementById(s)?document.getElementById(s):s;}
 
function keypress(e)
{
var e=e||event;
var currKey=e.keyCode||e.which||e.charCode;
if (currKey == 27)//ESC = 27
{
if (external != undefined)
{
external.KeyElvesClose("clear"); //關掉鍵盤精靈界面,傳clear則清空鍵盤精靈字符串,不傳或者為空則只關閉界面
}
}
else
{
if (external != undefined )
{
external.OpenCustomStockDlg(currKey); //向鍵盤精靈傳字符
}
}
$("test1").focus();//設置焦點
}
 
</script>
<body >
 
<input type="text" id="test1" onkeypress="keypress(event);"/>
<p>文本框內按鍵觸發鍵盤精靈</p>
</body>
</HTML>
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM