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 相关文章推荐
php图像生成函数之间的区别分析
Dec 06 Javascript
jQuery.extend()的实现方式详解及实例
Jun 29 Javascript
javascript修改IMG标签的src问题
Mar 28 Javascript
JS使用replace()方法和正则表达式进行字符串的搜索与替换实例
Apr 10 Javascript
分享两款带遮罩的jQuery弹出框
Dec 30 Javascript
jQuery实现的超简单点赞效果实例分析
Dec 31 Javascript
angular ng-repeat数组中的数组实例
Feb 18 Javascript
移动端触屏幻灯片图片切换插件idangerous swiper.js
Apr 10 Javascript
JavaScript禁用右键单击优缺点分析
Jan 20 Javascript
js实现一个简易计算器
Mar 30 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
Aug 02 Javascript
vue从一个页面跳转到另一个页面并携带参数的解决方法
Aug 12 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
php 遍历数据表数据并列表横向排列的代码
2009/09/05 PHP
php过滤html标记属性类用法实例
2014/09/23 PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
2015/04/09 PHP
php下载文件超时时间的设置方法
2016/10/06 PHP
PHP生成图片验证码功能示例
2017/01/12 PHP
Aster vs Newbee BO3 第三场2.18
2021/03/10 DOTA
jQuery Tools tab使用介绍
2012/07/14 Javascript
JavaScript实现快速排序(自已编写)
2012/12/19 Javascript
jQuery动态背景图片效果实现方法
2015/07/03 Javascript
jquery读写cookie操作实例分析
2015/12/24 Javascript
Nodejs 发送Post请求功能(发短信验证码例子)
2017/02/09 NodeJs
详解用node-images 打造简易图片服务器
2017/05/08 Javascript
Angular中ng-options下拉数据默认值的设定方法
2017/06/21 Javascript
vue组件实现文字居中对齐的方法
2017/08/23 Javascript
Element-ui table中过滤条件变更表格内容的方法
2018/03/02 Javascript
Vue数据双向绑定原理及简单实现方法
2018/05/18 Javascript
JavaScript中concat复制数组方法浅析
2019/01/20 Javascript
js实现列表向上无限滚动
2020/01/13 Javascript
原生JavaScript实现弹幕组件的示例代码
2020/10/12 Javascript
Python语法快速入门指南
2015/10/12 Python
基于Python实现文件大小输出
2016/01/11 Python
python爬取NUS-WIDE数据库图片
2016/10/05 Python
解决python3在anaconda下安装caffe失败的问题
2017/06/15 Python
Python地图绘制实操详解
2019/03/04 Python
Python企业编码生成系统之主程序模块设计详解
2019/07/26 Python
Python闭包及装饰器运行原理解析
2020/06/17 Python
Guess欧洲官网:美国服饰品牌
2019/08/06 全球购物
如何向接受结构参数的函数传入常数值
2016/02/17 面试题
自我评价中英文语句
2013/11/30 职场文书
大学新生军训感言
2014/02/25 职场文书
社会发展项目建议书
2014/08/25 职场文书
公证处委托书
2015/01/28 职场文书
朋友聚会祝酒词
2015/08/10 职场文书
职场:企业印章管理制度(模板)
2019/10/18 职场文书
python 实现体质指数BMI计算
2021/05/26 Python
SQL Server表分区删除详情
2021/10/16 SQL Server