如何在Web頁面上直接打開、編輯、建立Office文檔

穩萊

如何在Web頁面上直接打開、編輯、建立Office文檔

有朋友詢問如何在Web頁面上做到像SharePoint中的效果一樣,能直接激活客戶端的Word來打開.doc文件,而不是類似直接點擊.doc文檔鏈接時Word在IE中被打開那樣。想想這個問題應該很多人都會感興趣,所以乾脆寫一篇blog來大致描述一下方法。

在安裝Office2003以後,有一個ActiveX控件被安裝到了系統中,這個控件位於「Program Files\Microsoft Office\OFFICE11\owssupp.dll」。通過這個控件,客戶端頁面上的JavaScript就可以激活本地的Office軟體,來實現打開、編輯Office文檔。(另,Office XP應該就已經包含這個ActiveX控件了。)

首先,用Script建立一個本地的對象:

openDocObj = new ActiveXObject("SharePoint.OpenDocuments.2"); // 為了兼容Office XP,可以建立「SharePoint.OpenDocuments.1」

然後,調用openDocObj的相應的方法。比如打開伺服器上的一個Office文檔:

openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc");

openDocObj對像會根據參數中不同的Office文檔類型(.doc、.xls、.ppt)來打開不同的程式(Word、Excel、PowerPoint)。ViewDocument()方法還有一個重載簽名,可以讓我們手工指定激活哪個程式來打開文檔:

openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc", 要激活的程式的ProgID);

那麼要打開Office程式在線編輯文件又如何?

openDocObj.EditDocument("http://www.abc.com/documents/sample.doc");

就可以直接激活Word,在Word裡面編輯文檔,然後直接點擊Word裡面的保存功能,就可以將文件保存會伺服器上了。注意:為了讓Word能將編輯後的文檔直接保存會伺服器,訪問Web站點的當前上下文的Windows Identity必須對伺服器的相應目錄(即「http://www.abc.com/documents」這個虛擬目錄所對應的伺服器上的物理路徑)有相應的寫權限,否則保存動作會失敗。編輯完成後,EditDocument()會返回一個bool值,來反映編輯操作是否成功。

我們還可以通過打開伺服器上的一個文檔模版,來建立一個新的文檔:

openDocObj.CreateNewDocument("http://www.abc.com/documents/sampleTemplate.dot", "http://www.abc.com/documents/");

就可以使用「http://www.abc.com/documents/sampleTemplate.dot」這個模版來建立一個新的文檔,默認新文檔的保存地點是「http://www.abc.com/documents/」。建立新文檔時使用的程式取決於模版文件的類型(比如.dot模版會對應Word)。新文檔的保存同樣需要注意權限問題。CreateNewDocument()方法同樣會返回一個bool值來反映操作是否成功。

CreateNewDocument()方法的第一個參數,除了可以使用一個模版的地址外,還可以直接指定為希望用來建立新文檔的客戶端程式的ProgID。

 

 給當前日誌評分:
Loading Vote
正在讀取評分資料...


文章來自: Tank部落格
引用通告: 查看所有引用 | 我要引用此文章
Tags: WebOffice
相關日誌:

評論: 0 | 引用: 0 | 查看次數: -
發表評論
暱 稱:
密 碼: 遊客發言不需要密碼.
內 容:
驗證碼: 驗證碼
選 項:
雖然發表評論不用註冊,但是為了保護您的發言權,建議您註冊帳號.