使用Visual?Studio?2022開(kāi)發(fā)前端的詳細(xì)教程
前端開(kāi)發(fā)環(huán)境多數(shù)基于Node.js,好處不多說(shuō)了。但與使用Visual Studio開(kāi)發(fā)的后端Asp.Net Core項(xiàng)目一起調(diào)試,卻不是很方便,所以試著在Visual Studio 2022中開(kāi)發(fā)前端。
創(chuàng)建宿主項(xiàng)目
首先創(chuàng)建一個(gè)空的Asp.Net Core項(xiàng)目作為宿主,創(chuàng)建完成后將Program.cs中的代碼修改如下:
var builder = WebApplication.CreateBuilder(args); var app = builder.Build(); app.UseDefaultFiles(); app.UseStaticFiles(); app.Run();
app.UseStaticFiles()使這個(gè)Web應(yīng)用支持靜態(tài)文件,app.UseDefaultFiles()使這個(gè)Web應(yīng)用使用缺省的文件,比如index.html作為缺省的首頁(yè)。
然后在項(xiàng)目中創(chuàng)建wwwroot目錄,在這個(gè)目錄中,保存靜態(tài)文件。然后創(chuàng)建index.html,寫(xiě)個(gè)Hello World,就可以運(yùn)行了。
安裝前端庫(kù)
在瀏覽器中可以使用CDN源引用需要的客戶(hù)端庫(kù),可如果在企業(yè)內(nèi)網(wǎng)使用,無(wú)法訪問(wèn)CDN源時(shí),需要將客戶(hù)端庫(kù)下載到本地使用。
Visual Studio使用libman維護(hù)客戶(hù)端庫(kù)庫(kù)。在解決方案資源管理器的項(xiàng)目名稱(chēng)上按右鍵,選擇“管理客戶(hù)端庫(kù)”:

會(huì)在項(xiàng)目中創(chuàng)建libman.json文件,在這個(gè)文件中保存需要引用的客戶(hù)端庫(kù)。如果需要添加客戶(hù)端庫(kù),在解決方案資源管理器的項(xiàng)目名稱(chēng)上按右鍵,選擇添加->客戶(hù)端庫(kù):

可以搜索并選擇安裝的客戶(hù)端庫(kù)了:

在瀏覽器引入模塊
現(xiàn)在可以進(jìn)行客戶(hù)端開(kāi)發(fā)了,這種模式還是使用瀏覽器作為開(kāi)發(fā)運(yùn)行環(huán)境。好消息是瀏覽器也開(kāi)始支持引入模塊了,如Chrome和Edge已經(jīng)支持importmap,將js源導(dǎo)入為模塊。比如,下面的代碼引入vue:
<script type="importmap">
{
"imports": {
"vue": "./lib/vue/vue.esm-browser.js"
}
}
</script>在type="module"的script標(biāo)記中,可以使用import語(yǔ)句:
<script type="module">
import { createApp } from 'vue'
const myapp = {
data() {
return {
message: "你好"
}
}
}
const app = createApp(myapp)
app.mount('#app')
</script>如果使用Firefox等不支持importmap的瀏覽器,需要增加es-module-shims:
<script async src="https://ga.jspm.io/npm:es-module-shims@1.5.4/dist/es-module-shims.js"></script>
完整的代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<script async src="https://ga.jspm.io/npm:es-module-shims@1.5.4/dist/es-module-shims.js"></script>
</head>
<body>
<div id="app">
{{ message }}
</div>
<script type="importmap">
{
"imports": {
"vue": "./lib/vue/vue.esm-browser.js"
}
}
</script>
<script type="module">
import { createApp } from 'vue'
const myapp = {
data() {
return {
message: "你好"
}
}
}
const app = createApp(myapp)
app.mount('#app')
</script>
</body>
</html>模塊化開(kāi)發(fā)
在瀏覽器上直接開(kāi)發(fā),還不支持vue等后綴的模塊化文件,但可以使用js文件編寫(xiě)?yīng)毩⒌哪K,比如,下面的模塊保存在vuehello.js中:
export default {
data() {
return { message: "你好,模塊" }
},
template: `<div>{{ message }}</div>`
}在主頁(yè)面中可以使用importmap進(jìn)行映射,并使用import引用:
<div id="app">
{{ message }}
<hello></hello>
</div>
<script type="importmap">
{
"imports": {
"vue": "./lib/vue/vue.esm-browser.js",
"vuehello":"./js/vueHello.js"
}
}
</script>
<script type="module">
import { createApp } from 'vue'
import hello from 'vuehello'
const myapp = {
data() {
return {
message: "你好"
}
},
components :{
hello
}
}
const app = createApp(myapp)
app.mount('#app')
</script>運(yùn)行效果如下:

到此這篇關(guān)于使用Visual Studio 2022開(kāi)發(fā)前端的文章就介紹到這了,更多相關(guān)Visual Studio 2022前端內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript 頁(yè)面編碼與瀏覽器類(lèi)型判斷代碼
JavaScript 獲取瀏覽器的類(lèi)型和頁(yè)面編碼的函數(shù)代碼。2010-06-06
JavaScript插入動(dòng)態(tài)樣式實(shí)現(xiàn)代碼
能夠把CSS樣式包含到HTML頁(yè)面中的元素有兩個(gè)。其中,<link>元素用于包含來(lái)自外部的文件,而<style>元素用于指定嵌入的樣式2012-02-02
js點(diǎn)擊button按鈕跳轉(zhuǎn)到另一個(gè)新頁(yè)面
點(diǎn)擊按鈕怎么跳轉(zhuǎn)到另外一個(gè)頁(yè)面呢?點(diǎn)擊圖片要跳轉(zhuǎn)到新的頁(yè)面時(shí),怎么做到呢?可以使用onclick=window.location=新頁(yè)面來(lái)實(shí)現(xiàn)2014-10-10
uniapp項(xiàng)目?jī)?yōu)化方式及建議
性能優(yōu)化自古以來(lái)就是重中之重,本文關(guān)于uniapp項(xiàng)目?jī)?yōu)化方式最全整理,會(huì)根據(jù)開(kāi)發(fā)情況進(jìn)行補(bǔ)充,感興趣的可以了解一下2021-08-08
教你3分鐘利用原生js實(shí)現(xiàn)有進(jìn)度監(jiān)聽(tīng)的文件上傳預(yù)覽組件
這篇文章主要給大家介紹了關(guān)于如何3分鐘利用原生js實(shí)現(xiàn)有進(jìn)度監(jiān)聽(tīng)的文件上傳預(yù)覽組件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
鼠標(biāo)右擊事件代碼(asp.net后臺(tái))
本程序由一個(gè)js文件和aspx文件組成,沒(méi)有后臺(tái)CS代碼。2011-01-01
微信小程序?qū)崿F(xiàn)獲取小程序碼和二維碼java接口開(kāi)發(fā)
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)獲取小程序碼和二維碼java接口開(kāi)發(fā),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-03-03
JavaScript中具名函數(shù)的多種調(diào)用方式總結(jié)
這篇文章主要介紹了JavaScript中具名函數(shù)的多種調(diào)用方式總結(jié),本文總結(jié)了4種方法,需要的朋友可以參考下2014-11-11

