亚洲精品中文免费|亚洲日韩中文字幕制服|久久精品亚洲免费|一本之道久久免费

      
      

            <dl id="hur0q"><div id="hur0q"></div></dl>

                Three.js入門 第三章 用webpack+ts 開發(fā)three 項(xiàng)目

                我們之前說(shuō)webgl的時(shí)候,是以夯實(shí)基礎(chǔ)為目的。

                而現(xiàn)在的three,我會(huì)逐步往實(shí)戰(zhàn)靠攏。

                現(xiàn)在,webpack 依舊是主流的模塊打包工具,這在大部分公司的項(xiàng)目開發(fā)中是必不可少的。

                ts和three 是絕配,three本身就是用ts寫的,ts可以為three 項(xiàng)目提前做好規(guī)則約束,使項(xiàng)目的開發(fā)更加順暢。

                因此,我接下來(lái)會(huì)跟大說(shuō)一下如何用webpack+ts 寫three。

                對(duì)于主流的前端框架vue、react,前期還不是特別需要,我會(huì)放到后面說(shuō)。

                我當(dāng)前選擇的webpack 是最新版本的webpack 5,具體指南可參考官網(wǎng)。

                1.創(chuàng)建一個(gè)目錄,初始化 npm

                mkdir 01-startcd 01-startnpm init -y

                2.調(diào)整 package.json 文件,以便確保我們安裝包是 private(私有的),并且移除 main 入口。這可以防止意外發(fā)布你的代碼。

                { “name”: “webpack-demo”, “version”: “1.0.0”, “description”: “”,- “main”: “index.js”,+ “private”: true, “scripts”: { “test”: “echo “Error: no test specified” && exit 1″ }, “keywords”: [], “author”: “”, “license”: “MIT”, “devDependencies”: { “webpack”: “^5.38.1”, “webpack-cli”: “^4.7.2”, } }

                3.安裝依賴文件

                • webpack 相關(guān)的依賴

                npm install webpack webpack-cli webpack-dev-server –save-dev

                • ts 相關(guān)的依賴

                npm install typescript ts-loader –save-dev

                • three 相關(guān)的依賴

                npm install three @types/three –save

                package.json 如下:

                { “name”: “three-lesson-02”, “version”: “1.0.0”, “description”: “”, “private”: true, “scripts”: { “test”: “echo “Error: no test specified” && exit 1″, “start”: “webpack serve –open”, }, “keywords”: [], “author”: “”, “license”: “ISC”, “devDependencies”: { “ts-loader”: “^9.2.8”, “typescript”: “^4.6.2”, “webpack”: “^5.70.0”, “webpack-cli”: “^4.9.2”, “webpack-dev-server”: “^4.7.4” }, “dependencies”: { “@types/three”: “^0.138.0”, “three”: “^0.138.3” }}

                4.建立項(xiàng)目文件。

                • 目錄結(jié)構(gòu)

                01-start|- dist |- 01-helloWorld.html|- src |- helloWorld.ts|- package.json|- package-lock.json|- tsconfig.json|- webpack.config.js

                • dist/01-helloWorld.html

                helloWorld body { margin: 0; overflow: hidden; }

                • src/helloWorld.ts

                const str:string=’Hello World’console.log(str)

                • webpack.config.js

                const path = require(‘path’);module.exports = { mode: ‘development’, entry: { helloWorld: ‘./src/helloWorld.ts’, }, devtool: ‘inline-source-map’, devServer: { static: ‘./dist’, }, output: { filename: ‘[name].js’, path: path.resolve(__dirname, ‘dist’), }, resolve: { extensions: [“.ts”, “.tsx”, “.js”] }, module: { rules: [ { test: /.tsx?$/, loader: “ts-loader” } ] }};

                • tsconfig.json

                { “compilerOptions”: { “sourceMap”: true, “target”: “es6”, “module”: “es6” }}

                5.運(yùn)行項(xiàng)目,若在01-helloWorld.html中打印出“Hello World”,就說(shuō)明配置沒(méi)有問(wèn)題。

                npm run start

                6.多頁(yè)面。

                在dist 中再建立一個(gè)頁(yè)面 02-box.html,用來(lái)顯示我們入門時(shí)繪制的立方體。

                box body { margin: 0; overflow: hidden; }

                在src 中建立一個(gè)box.js 文件,用于繪制立方體:

                import { BoxGeometry,Mesh,MeshNormalMaterial,PerspectiveCamera,Scene,WebGLRenderer,} from ‘three’const scene = new Scene()const camera = new PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 0.1, 1000 )const canvas = document.getElementById(‘canvas’);canvas.width = window.innerWidth;canvas.height = window.innerHeight;const renderer = new WebGLRenderer({canvas});const geometry = new BoxGeometry();const material = new MeshNormalMaterial();const cube = new Mesh( geometry, material )scene.add( cube );camera.position.z = 5;function animate() { requestAnimationFrame( animate ) cube.rotation.x += 0.01 cube.rotation.y += 0.01 renderer.render( scene, camera )};animate();

                在webpack.config.js 中添加彩色立方體頁(yè)面所對(duì)應(yīng)的入口

                module.exports = { …… entry: { helloWorld: ‘./src/helloWorld.ts’, box: ‘./src/box.ts’, }, ……};

                啟服務(wù)后,打開box.html 頁(yè)面,便可以看見旋轉(zhuǎn)的立方體。

                鄭重聲明:本文內(nèi)容及圖片均整理自互聯(lián)網(wǎng),不代表本站立場(chǎng),版權(quán)歸原作者所有,如有侵權(quán)請(qǐng)聯(lián)系管理員(admin#wlmqw.com)刪除。
                用戶投稿
                上一篇 2022年6月13日 15:23
                下一篇 2022年6月13日 15:24

                相關(guān)推薦

                • 30個(gè)無(wú)加盟費(fèi)的項(xiàng)目(茶顏悅色奶茶店加盟費(fèi)多少)

                  茶顏悅色又爆了,8月18日,茶顏悅色南京門店正式開業(yè),開張不到半小時(shí),門店就人滿為患,消費(fèi)者的購(gòu)買熱情十分高漲,而由于人流量過(guò)大造成擁堵,茶顏悅色也不得不暫停營(yíng)業(yè)。 當(dāng)然,這里面排…

                  2022年11月27日
                • 凈利潤(rùn)率越高越好嗎(凈利潤(rùn)率多少合適)

                  一、持續(xù)增收不增利,平均凈利潤(rùn)率首次跌入個(gè)位數(shù) 2021年,增收不增利依舊是行業(yè)主流。具體來(lái)看,大部分企業(yè)營(yíng)業(yè)收入呈增長(zhǎng)態(tài)勢(shì),E50企業(yè)平均同比增速達(dá)到17.3%,但是利潤(rùn)增速則明…

                  2022年11月26日
                • 抖音帶貨怎么做入門(抖音帶貨怎么做入門教學(xué))

                  相信很多小伙伴都有注意到,現(xiàn)在抖音已經(jīng)成為大家最常光顧的一個(gè)平臺(tái)了,作為一個(gè)日活破億的流量池,如今抖音上的用戶數(shù)量極大。因此,現(xiàn)在在抖音上帶貨、賣貨的人也是越來(lái)越多了,那么想在抖音…

                  2022年11月25日
                • 規(guī)范透明促PPP高質(zhì)量發(fā)展——16萬(wàn)億元大市場(chǎng)迎來(lái)新規(guī)

                  近日,財(cái)政部印發(fā)《關(guān)于進(jìn)一步推動(dòng)政府和社會(huì)資本合作(PPP)規(guī)范發(fā)展、陽(yáng)光運(yùn)行的通知》,從做好項(xiàng)目前期論證、推動(dòng)項(xiàng)目規(guī)范運(yùn)作、嚴(yán)防隱性債務(wù)風(fēng)險(xiǎn)、保障項(xiàng)目陽(yáng)光運(yùn)行四個(gè)方面進(jìn)一步規(guī)范P…

                  2022年11月25日
                • 拼多多百億補(bǔ)貼預(yù)售一般多久發(fā)貨(拼多多百億補(bǔ)貼預(yù)售)

                  拼多多里面有很多優(yōu)惠活動(dòng),其中百億補(bǔ)貼活動(dòng)非?;鸨?,一些里面的東西價(jià)格比別的平臺(tái)便宜,質(zhì)量也有保障,還有預(yù)售的活動(dòng),那么拼多多百億補(bǔ)貼預(yù)售一般多久發(fā)貨?下面小編為大家?guī)?lái)拼多多百億…

                  2022年11月25日
                • 推薦3種白手起家的賺錢項(xiàng)目(白手起家賺錢項(xiàng)目有哪些)

                  如今社會(huì)壓力非常的大,家有老少要養(yǎng)活,這些都加速了窮人想要?jiǎng)?chuàng)業(yè)的欲望,但是創(chuàng)業(yè)路總是那么的艱難,資金就是創(chuàng)業(yè)的重頭戲,所以選擇一個(gè)低成本又賺錢的項(xiàng)目是大多數(shù)人最期望的了,那么有哪些…

                  2022年11月25日
                • 百度關(guān)鍵詞快速排名的4大原理解析(百度怎么刷關(guān)鍵詞)

                  近期百度公告驚雷算法2.0,升級(jí)之快還是第一次吧,看來(lái)百度對(duì)于刷點(diǎn)擊行為是零容忍了。之前尹華峰SEO技術(shù)博客介紹過(guò)一篇如何使用刷點(diǎn)擊工具,其實(shí)市面上有很多這類SEO快速排名的軟件,…

                  2022年11月25日
                • 科比19歲女兒遭自稱與她生“科比式孩子”男子跟蹤騷擾

                  極目新聞?dòng)浾咄趿亮咙S佳琪 據(jù)??怂剐侣劸W(wǎng)報(bào)道,當(dāng)?shù)貢r(shí)間11月21日,已故籃球巨星科比·布萊恩特的長(zhǎng)女娜塔莉亞·布萊恩特21日向法院提交臨時(shí)限制令,聲稱這位32歲的前科從十幾歲起就騷…

                  2022年11月24日
                • Steam秋季特賣開啟 為Steam大獎(jiǎng)提名游戲

                  Steam秋季特賣開啟 為Steam大獎(jiǎng)提名游戲 Steam秋季特賣活動(dòng)現(xiàn)已正式開啟,時(shí)間從11月23日持續(xù)到11月30日(北京時(shí)間),新老游戲均有不錯(cuò)的折扣,感興趣的玩家可以前往…

                  2022年11月24日
                • 免費(fèi)清理c盤的軟件(清理c盤空間不影響系統(tǒng))

                  電腦用久了慢如龜速,還卡頓,這最大的原因啊就是C盤空間不足造成的。 即使電腦配置再好,或者硬盤再快,如果長(zhǎng)時(shí)間沒(méi)有打掃C盤,打開文件或者穩(wěn)定之類的,都卡得讓人頭大。 這時(shí)候呢不要去…

                  2022年11月24日

                聯(lián)系我們

                聯(lián)系郵箱:admin#wlmqw.com
                工作時(shí)間:周一至周五,10:30-18:30,節(jié)假日休息