如何在Web頁面上直接打開、編輯、創(chuàng)建Office文檔
更新時(shí)間:2007年03月12日 00:00:00 作者:
如何在Web頁面上直接打開、編輯、創(chuàng)建Office文檔
有朋友詢問如何在Web頁面上做到像SharePoint中的效果一樣,能直接激活客戶端的Word來打開.doc文件,而不是類似直接點(diǎn)擊.doc文檔鏈接時(shí)Word在IE中被打開那樣。想想這個(gè)問題應(yīng)該很多人都會(huì)感興趣,所以干脆寫一篇blog來大致描述一下方法。
在安裝Office2003以后,有一個(gè)ActiveX控件被安裝到了系統(tǒng)中,這個(gè)控件位于“Program Files\Microsoft Office\OFFICE11\owssupp.dll”。通過這個(gè)控件,客戶端頁面上的JavaScript就可以激活本地的Office軟件,來實(shí)現(xiàn)打開、編輯Office文檔。(另,Office XP應(yīng)該就已經(jīng)包含這個(gè)ActiveX控件了。)
首先,用Script創(chuàng)建一個(gè)本地的對(duì)象:
openDocObj = new ActiveXObject("SharePoint.OpenDocuments.2"); // 為了兼容Office XP,可以創(chuàng)建“SharePoint.OpenDocuments.1”
然后,調(diào)用openDocObj的相應(yīng)的方法。比如打開服務(wù)器上的一個(gè)Office文檔:
openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc");
openDocObj對(duì)象會(huì)根據(jù)參數(shù)中不同的Office文檔類型(.doc、.xls、.ppt)來打開不同的程序(Word、Excel、PowerPoint)。ViewDocument()方法還有一個(gè)重載簽名,可以讓我們手工指定激活哪個(gè)程序來打開文檔:
openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc", 要激活的程序的ProgID);
那么要打開Office程序在線編輯文件又如何?
openDocObj.EditDocument("http://www.abc.com/documents/sample.doc");
就可以直接激活Word,在Word里面編輯文檔,然后直接點(diǎn)擊Word里面的保存功能,就可以將文件保存會(huì)服務(wù)器上了。注意:為了讓W(xué)ord能將編輯后的文檔直接保存會(huì)服務(wù)器,訪問Web站點(diǎn)的當(dāng)前上下文的Windows Identity必須對(duì)服務(wù)器的相應(yīng)目錄(即“http://www.abc.com/documents”這個(gè)虛擬目錄所對(duì)應(yīng)的服務(wù)器上的物理路徑)有相應(yīng)的寫權(quán)限,否則保存動(dòng)作會(huì)失敗。編輯完成后,EditDocument()會(huì)返回一個(gè)bool值,來反映編輯操作是否成功。
我們還可以通過打開服務(wù)器上的一個(gè)文檔模版,來創(chuàng)建一個(gè)新的文檔:
openDocObj.CreateNewDocument("http://www.abc.com/documents/sampleTemplate.dot", "http://www.abc.com/documents/");
就可以使用“http://www.abc.com/documents/sampleTemplate.dot”這個(gè)模版來創(chuàng)建一個(gè)新的文檔,默認(rèn)新文檔的保存地點(diǎn)是“http://www.abc.com/documents/”。創(chuàng)建新文檔時(shí)使用的程序取決于模版文件的類型(比如.dot模版會(huì)對(duì)應(yīng)Word)。新文檔的保存同樣需要注意權(quán)限問題。CreateNewDocument()方法同樣會(huì)返回一個(gè)bool值來反映操作是否成功。
CreateNewDocument()方法的第一個(gè)參數(shù),除了可以使用一個(gè)模版的地址外,還可以直接指定為希望用來創(chuàng)建新文檔的客戶端程序的ProgID。
有朋友詢問如何在Web頁面上做到像SharePoint中的效果一樣,能直接激活客戶端的Word來打開.doc文件,而不是類似直接點(diǎn)擊.doc文檔鏈接時(shí)Word在IE中被打開那樣。想想這個(gè)問題應(yīng)該很多人都會(huì)感興趣,所以干脆寫一篇blog來大致描述一下方法。
在安裝Office2003以后,有一個(gè)ActiveX控件被安裝到了系統(tǒng)中,這個(gè)控件位于“Program Files\Microsoft Office\OFFICE11\owssupp.dll”。通過這個(gè)控件,客戶端頁面上的JavaScript就可以激活本地的Office軟件,來實(shí)現(xiàn)打開、編輯Office文檔。(另,Office XP應(yīng)該就已經(jīng)包含這個(gè)ActiveX控件了。)
首先,用Script創(chuàng)建一個(gè)本地的對(duì)象:
openDocObj = new ActiveXObject("SharePoint.OpenDocuments.2"); // 為了兼容Office XP,可以創(chuàng)建“SharePoint.OpenDocuments.1”
然后,調(diào)用openDocObj的相應(yīng)的方法。比如打開服務(wù)器上的一個(gè)Office文檔:
openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc");
openDocObj對(duì)象會(huì)根據(jù)參數(shù)中不同的Office文檔類型(.doc、.xls、.ppt)來打開不同的程序(Word、Excel、PowerPoint)。ViewDocument()方法還有一個(gè)重載簽名,可以讓我們手工指定激活哪個(gè)程序來打開文檔:
openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc", 要激活的程序的ProgID);
那么要打開Office程序在線編輯文件又如何?
openDocObj.EditDocument("http://www.abc.com/documents/sample.doc");
就可以直接激活Word,在Word里面編輯文檔,然后直接點(diǎn)擊Word里面的保存功能,就可以將文件保存會(huì)服務(wù)器上了。注意:為了讓W(xué)ord能將編輯后的文檔直接保存會(huì)服務(wù)器,訪問Web站點(diǎn)的當(dāng)前上下文的Windows Identity必須對(duì)服務(wù)器的相應(yīng)目錄(即“http://www.abc.com/documents”這個(gè)虛擬目錄所對(duì)應(yīng)的服務(wù)器上的物理路徑)有相應(yīng)的寫權(quán)限,否則保存動(dòng)作會(huì)失敗。編輯完成后,EditDocument()會(huì)返回一個(gè)bool值,來反映編輯操作是否成功。
我們還可以通過打開服務(wù)器上的一個(gè)文檔模版,來創(chuàng)建一個(gè)新的文檔:
openDocObj.CreateNewDocument("http://www.abc.com/documents/sampleTemplate.dot", "http://www.abc.com/documents/");
就可以使用“http://www.abc.com/documents/sampleTemplate.dot”這個(gè)模版來創(chuàng)建一個(gè)新的文檔,默認(rèn)新文檔的保存地點(diǎn)是“http://www.abc.com/documents/”。創(chuàng)建新文檔時(shí)使用的程序取決于模版文件的類型(比如.dot模版會(huì)對(duì)應(yīng)Word)。新文檔的保存同樣需要注意權(quán)限問題。CreateNewDocument()方法同樣會(huì)返回一個(gè)bool值來反映操作是否成功。
CreateNewDocument()方法的第一個(gè)參數(shù),除了可以使用一個(gè)模版的地址外,還可以直接指定為希望用來創(chuàng)建新文檔的客戶端程序的ProgID。
相關(guān)文章
js仿支付寶填寫支付密碼效果實(shí)現(xiàn)多方框輸入密碼
這篇文章主要介紹了js仿支付寶填寫支付密碼效果實(shí)現(xiàn)多方框輸入密碼的功能,感興趣的小伙伴們可以參考一下2016-03-03Javascript表單序列化原理及實(shí)現(xiàn)代碼詳解
這篇文章主要介紹了Javascript表單序列化原理及實(shí)現(xiàn)代碼詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10JavaScrpt判斷一個(gè)數(shù)是否是質(zhì)數(shù)的實(shí)例代碼
本文通過實(shí)例代碼給大家分享了JavaScrpt判斷一個(gè)數(shù)是否是質(zhì)數(shù),需要的朋友參考下吧2017-06-06JS+CSS實(shí)現(xiàn)的藍(lán)色table選項(xiàng)卡效果
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)的藍(lán)色table選項(xiàng)卡效果,通過鼠標(biāo)事件調(diào)用自定義函數(shù)實(shí)現(xiàn)頁面元素樣式的遍歷與動(dòng)態(tài)切換效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10BootStrap Table 分頁后重新搜索問題的解決辦法
這篇文章主要介紹了BootStrap Table 分頁后重新搜索問題的解決辦法,自定義搜索且有分頁功能,比如搜索產(chǎn)品名的功能。小編給大家?guī)砹岁P(guān)鍵代碼,非常不錯(cuò),需要的朋友可以參考下2016-08-08layui實(shí)現(xiàn)點(diǎn)擊按鈕給table添加一行
想實(shí)現(xiàn)點(diǎn)擊按鈕在表格添加一行的功能,但發(fā)現(xiàn)layui并未集成該工具欄,因此,需要自己手動(dòng)添加這個(gè)功能;這篇文章主要介紹了layui點(diǎn)擊按鈕給table添加一行,需要的朋友可以參考下2018-08-08JavaScript使用indexOf獲得子字符串在字符串中位置的方法
這篇文章主要介紹了JavaScript使用indexOf獲得子字符串在字符串中位置的方法,涉及javascript中indexOf方法操作字符串的技巧,需要的朋友可以參考下2015-04-04JS實(shí)現(xiàn)的最簡Table選項(xiàng)卡效果
這篇文章主要介紹了JS實(shí)現(xiàn)的最簡Table選項(xiàng)卡效果,涉及簡單的JavaScript響應(yīng)鼠標(biāo)事件切換樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10