three.js中文文档学习之如何本地运行详解


Posted in Javascript onNovember 20, 2017

前言

本文属于系列问题,需要的朋友们开始之前可以参考以下的两篇文章:

1、three.js中文文档学习之创建场景

2、three.js中文文档学习之通过模块导入

如果你只是使用程序化的几何体,不需要加载任何材质,网页应该直接从文件系统加载,只需要双击文件管理器中 HTML 文件,应该在你的浏览器能够运行(地址栏长这样子:file:///yourFile.html)

从外部文件加载内容

如果你从外部文件下载模块和材质,由于浏览器的 同源政策 的安全限制,会引发安全异常而加载失败。

有两种解决办法:

在浏览器中对于本地文件修改安全性。你才能这样进入网页:

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 中有讨论。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
vs2003 js文件编码问题的解决方法
Mar 20 Javascript
js中函数调用的两种常用方法使用介绍
Jul 17 Javascript
JavaScript实现弹出子窗口并传值给父窗口
Dec 18 Javascript
js操作XML文件的实现方法兼容IE与FireFox
Jun 25 Javascript
JS实现课堂随机点名和顺序点名
Mar 09 Javascript
jQuery实现jQuery-form.js实现异步上传文件
Apr 28 jQuery
基于node.js制作简单爬虫教程
Jun 29 Javascript
webpack 2的react开发配置实例代码
Jul 28 Javascript
Vue2.0+ElementUI实现表格翻页的实例
Oct 23 Javascript
详解vue指令与$nextTick 操作DOM的不同之处
Aug 02 Javascript
vue框架下部署上线后刷新报404问题的解决方案(推荐)
Apr 03 Javascript
Javascript摸拟自由落体与上抛运动原理与实现方法详解
Apr 08 Javascript
AngularJS实现自定义指令及指令配置项的方法
Nov 20 #Javascript
详解webpack + react + react-router 如何实现懒加载
Nov 20 #Javascript
详细分析jsonp的原理和实现方式
Nov 20 #Javascript
three.js中文文档学习之通过模块导入
Nov 20 #Javascript
JS写XSS cookie stealer来窃取密码的步骤详解
Nov 20 #Javascript
浅谈Vue SSR 的 Cookies 问题
Nov 20 #Javascript
three.js中文文档学习之创建场景
Nov 20 #Javascript
You might like
10个简化PHP开发的工具
2014/12/25 PHP
php实现将Session写入数据库
2015/07/26 PHP
PHP简单获取随机数的常用方法小结
2017/06/07 PHP
PHP论坛实现积分系统的思路代码详解
2020/06/01 PHP
基于jquery的商品展示放大镜
2010/08/07 Javascript
javascript实现类似java中getClass()得到对象类名的方法
2015/07/27 Javascript
jQuery实现带延时功能的水平多级菜单效果【附demo源码下载】
2016/09/21 Javascript
JS常用函数和常用技巧小结
2016/10/15 Javascript
Javascript 数组去重的方法(四种)详解及实例代码
2016/11/24 Javascript
js实现音频控制进度条功能
2017/04/01 Javascript
分享19个JavaScript 有用的简写写法
2017/07/07 Javascript
详解vue 组件之间使用eventbus传值
2017/10/25 Javascript
vue中引用swiper轮播插件的教程详解
2018/08/16 Javascript
JavaScript创建对象方法实例小结
2018/09/03 Javascript
vue组件之间通信方式实例总结【8种方式】
2019/02/22 Javascript
webpack 如何同时输出压缩和未压缩的文件的实现步骤
2020/06/05 Javascript
[01:13:59]LGD vs Mineski Supermajor 胜者组 BO3 第三场 6.5
2018/06/06 DOTA
详解Python命令行解析工具Argparse
2016/04/20 Python
python查询文件夹下excel的sheet名代码实例
2019/04/02 Python
Django认证系统实现的web页面实现代码
2019/08/12 Python
Python3监控疫情的完整代码
2020/02/20 Python
django实现后台显示媒体文件
2020/04/07 Python
python2.7使用scapy发送syn实例
2020/05/05 Python
python入门:argparse浅析 nargs='+'作用
2020/07/12 Python
Python 如何创建一个线程池
2020/07/28 Python
详解Canvas事件绑定
2018/06/27 HTML / CSS
俄罗斯首家面向中国消费者的一站式购物网站:Wruru
2020/05/08 全球购物
特色冷饮店创业计划书
2014/01/28 职场文书
餐饮部总监岗位职责范文
2014/02/13 职场文书
观看信仰心得体会
2014/09/04 职场文书
2014年培训工作总结范文
2014/11/27 职场文书
工会文体活动总结
2015/05/07 职场文书
微信早安问候语
2015/11/10 职场文书
Ajax常用封装库——Axios的使用
2021/05/08 Javascript
MongoDB orm框架的注意事项及简单使用
2021/06/20 MongoDB
python模板入门教程之flask Jinja
2022/04/11 Python