首頁 web前端 js教程 three.js如何本地運行詳解

three.js如何本地運行詳解

Jan 16, 2018 pm 01:07 PM
javascript 詳解

本文主要為大家介紹了關於three.js中文文件學習之如何在本地運行的相關資料,文中透過範例程式碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

從外部檔案載入內容

如果你從外部檔案下載模組和材質,由於瀏覽器的 同源政策 的安全限制,會引發安全性異常而載入失敗。

有兩種解決方法:

在瀏覽器中對於本機檔案修改安全性。你才能這樣進入網頁:

file:///yourFile.html
登入後複製

從本地web 伺服器運行文件,你能這樣進入網頁:

http://localhost/yourFile.html
登入後複製

如果你使用第一種,要注意你使用同一個瀏覽器(修改安全性之後的)進行正常上網時會讓自己處於易受攻擊狀態。你可以建立一個獨立的瀏覽器配置和快捷方式,僅用作本地開發來確保安全。讓我們依序看看每種方法。

運行本機伺服器

很多程式語言有內建的 HTTP 伺服器。他們沒有像 Apache或 NGINX的全部功能,但對於測試 three.js 應用已經足夠。

Node.js 伺服器

有一個簡單的HTTP 伺服器安裝包,安裝:

npm install http-server -g
登入後複製

執行:

http-server -p 8000
登入後複製

Python 伺服器

如果你安裝了Python,在你的工作目錄下執行以下命令列:

//Python 2.x
python -m SimpleHTTPServer

//Python 3.x
python -m http.server
登入後複製

會從目前目錄到localhost 的80 連接埠發起服務,網址列是這樣:

http://localhost:8000/
登入後複製

PHP 伺服器

PHP 也有內建的web 伺服器,php 5.4.0 及以後:

php -S localhost:8000
登入後複製

Ruby 伺服器

如果你安裝了這個,你可以運行如下程式碼:

ruby -r webrick -e "s = WEBrick::HTTPServer.new(:Port => 8000, :DocumentRoot => Dir.pwd); trap('INT') { s.shutdown }; s.start"
登入後複製

Lighttpd

它是一個非常輕量的通用web伺服器。我們以安裝了 HomeBrew 的 OSX 系統為例。不像上述伺服器,lighttpd 是一個成熟的伺服器產品。

透過 homebrew 安裝

brew install loghttpd
登入後複製

在你想執行 web 伺服器的地方建立一個名為 lighttpd.conf 的設定檔。範例:

server.document-root = "/var/www/servers/www.example.org/pages/"

server.port = 3000

mimetype.assign = (
 ".html" => "text/html", 
 ".txt" => "text/plain",
 ".jpg" => "image/jpeg",
 ".png" => "image/png" 
)
登入後複製

在設定檔中,改變 server.document-root 到你需要服務的目錄。

開啟:

lighttpd -f lighttpd.conf
登入後複製

輸入 http://localhost:3000/ 就能從你選擇的目錄提供靜態檔案的服務。

改變本機檔案的安全性政策

Safari

#使用偏好設定面板開啟開發者選項:進階-> "在選單欄中顯示開發功能表".

然後在開發-> 停用本機檔案限制。如果你使用 Safari 來編輯和調試的話,值得注意的是 safari 對於快取總是有異常行為,所以在同樣的選單下點擊 停用快取 是個明智的選擇。

chrome

先關閉所有執行的chrome 實例,記住是所有。

在 Windows下,你需要用進程管理器檢查是否都關閉了。或者,如果你在系統托盤裡看見了 chrome 圖標,打開右鍵選單點擊 退出。應該能關閉所有實例。

然後透過命令列標記啟動 chrome 程式:

chrome --allow-file-access-from-files
登入後複製

在 Window 下,最簡單的方法就是建立一個特殊的快捷方式圖標,在結尾添加如上的標識。 (右鍵chrome 的捷徑-> 屬性-> 目標)

Firefox

在網址列,輸入about:config

找到security .fileuri.strict_origin_policy 參數

設定為false

其他簡單都方法也在Stack Overflow 中有討論。

相關推薦:

Three.js實作3D地圖實例分享

three.js編寫的一個專案類別範例程式碼分享

實例講解Three.js載入外部模型

#

以上是three.js如何本地運行詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Win11管理員權限取得詳解 Win11管理員權限取得詳解 Mar 08, 2024 pm 03:06 PM

Windows作業系統是全球最受歡迎的作業系統之一,其新版本Win11備受矚目。在Win11系統中,管理員權限的取得是一個重要的操作,管理員權限可以讓使用者對系統進行更多的操作和設定。本文將詳細介紹在Win11系統中如何取得管理員權限,以及如何有效地管理權限。在Win11系統中,管理員權限分為本機管理員和網域管理員兩種。本機管理員是指具有對本機電腦的完全管理權限

Oracle SQL中的除法運算詳解 Oracle SQL中的除法運算詳解 Mar 10, 2024 am 09:51 AM

OracleSQL中的除法運算詳解在OracleSQL中,除法運算是一種常見且重要的數學運算運算,用來計算兩個數相除的結果。除法在資料庫查詢中經常用到,因此了解OracleSQL中的除法運算及其用法是資料庫開發人員必備的技能之一。本文將詳細討論OracleSQL中除法運算的相關知識,並提供具體的程式碼範例供讀者參考。一、OracleSQL中的除法運算

PHP模運算子的作用及用法詳解 PHP模運算子的作用及用法詳解 Mar 19, 2024 pm 04:33 PM

PHP中的模運算子(%)是用來取得兩個數值相除的餘數的。在本文中,我們將詳細討論模運算子的作用及用法,並提供具體的程式碼範例來幫助讀者更好地理解。 1.模運算子的作用在數學中,當我們將一個整數除以另一個整數時,就會得到一個商和一個餘數。例如,當我們將10除以3時,商數為3,餘數為1。模運算子就是用來取得這個餘數的。 2.模運算子的用法在PHP中,使用%符號來表示模

linux系統呼叫system()函數詳解 linux系統呼叫system()函數詳解 Feb 22, 2024 pm 08:21 PM

Linux系統呼叫system()函數詳解系統呼叫是Linux作業系統中非常重要的一部分,它提供了一種與系統核心互動的方式。其中,system()函數是常用的系統呼叫函數之一。本文將詳細介紹system()函數的使用方法,並提供對應的程式碼範例。系統呼叫的基本概念系統呼叫是使用者程式與作業系統核心互動的一種方式。使用者程式透過呼叫系統呼叫函數來請求作業系統

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

Linux的curl指令詳解 Linux的curl指令詳解 Feb 21, 2024 pm 10:33 PM

Linux的curl命令詳解摘要:curl是一種強大的命令列工具,用於與伺服器進行資料通訊。本文將介紹curl指令的基本用法,並提供實際的程式碼範例,幫助讀者更好地理解和應用該指令。一、curl是什麼? curl是命令列工具,用於發送和接收各種網路請求。它支援多種協議,如HTTP、FTP、TELNET等,並提供了豐富的功能,如檔案上傳、檔案下載、資料傳輸、代

深入了解Promise.resolve() 深入了解Promise.resolve() Feb 18, 2024 pm 07:13 PM

Promise.resolve()詳解,需要具體程式碼範例Promise是JavaScript中一種用來處理非同步操作的機制。在實際開發中,常常需要處理一些需要依序執行的非同步任務,而Promise.resolve()方法就是用來傳回一個已經Fulfilled狀態的Promise物件。 Promise.resolve()是Promise類別的靜態方法,它接受一個

numpy版本查詢方法詳解 numpy版本查詢方法詳解 Jan 19, 2024 am 08:20 AM

Numpy是一款Python科學計算庫,提供了豐富的陣列操作函數與工具。升級Numpy版本時需要查詢目前版本以確保相容性,本文將詳細介紹Numpy版本查詢的方法,並提供具體的程式碼範例。方法一:使用Python程式碼查詢Numpy版本使用Python程式碼可以輕鬆查詢Numpy的版本,以下是實作方法和範例程式碼:importnumpyasnpprint(np

See all articles