- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我是 VueJS 的新手
我有一个多页面 ASP.NET MVC 应用程序,我想在其中使用 VueJS(组件、双向绑定(bind)、验证、CRUD 操作)
目前使用 jQuery 进行 DOM 操作、Ajax 请求等
我应该如何处理这个问题?我从不同的帖子(在线)中获得了太多不同的想法
谁能指导我并给我一些入门指南?
一些循序渐进的文档会很棒,它展示了如何使用带有 vuejs 单文件组件和捆绑的 hello world 页面(MVC View )执行此操作
捆绑似乎是一个复杂的过程。但我很乐意在我的代码中使用 LESS
感谢阅读
最佳答案
非常基础
据我所知,在 ASP.NET 中开始使用 Vue 的最基本方法就是在项目中包含 Vue 脚本。您可以使用 vue.js Nuget 包,它将 Vue 脚本添加到您的脚本目录中,并且只在您的 MVC View 中包含开发版本或缩小版本。
<script src="~/Scripts/vue.min.js"></script>
然后在你的 View cshtml中,添加一个脚本 block 即可。
<script>
new Vue({
el: "#app",
data: {
message: "Hello from Vue"
}
})
</script>
其中 #app
指的是您 View 中的一个元素。如果你想使用一个组件,只需将它添加到你的脚本 block 。
<script>
Vue.component("child", {
template:"<h1>I'm a child component!</h1>"
})
new Vue({
el: "#app",
data: {
message: "Hello from Vue"
}
})
</script>
并修改你的 Vue 模板。
<div id="app">
{{message}}
<child></child>
</div>
如果您发现自己构建了很多组件(您可能会这样做),请将它们提取到 vue.components.js 文件或类似的文件中,在那里定义所有组件,并将其包含在 View 中以及 vue 中脚本。
使用单个文件组件
为了使用单文件组件,您需要将单文件组件的 node.js 构建过程集成到您的 ASP.NET MVC 构建过程中。
安装 node.js . node.js安装完成后,全局安装webpack。
npm install webpack -g
将 package.json 添加到您的项目。这是我使用的。
{
"version": "1.0.0",
"name": "vue-example",
"private": true,
"devDependencies": {
"babel-core": "^6.23.1",
"babel-loader": "^6.3.2",
"babel-preset-env": "^1.1.8",
"css-loader": "^0.26.1",
"style-loader": "^0.13.1",
"vue-loader": "^11.1.0",
"vue-template-compiler": "^2.1.10",
"webpack": "^2.2.0"
},
"dependencies": {
"vue": "^2.2.1"
}
}
我通常会在我的项目中创建一个名为 Vue 的文件夹来保存我的 Vue 脚本和 .vue 文件。添加一个文件作为 Vue 构建过程的入口点。我们可以将其称为 index.js(或您想要的任何名称)。
import Vue from 'vue'
import App from './App.vue'
new Vue({
el: '#app',
render: h => h(App)
})
创建 App.vue。
<template>
<div id="app">
{{msg}}
</div>
</template>
<script>
export default {
name: 'app',
data () {
return {
msg: 'Welcome to Your Vue.js App'
}
}
}
</script>
将 webpack.config.js 添加到您的项目中。这是我使用的。
module.exports = {
entry: "./Vue/index.js",
output: {
path: __dirname,
filename: "./Vue/bundle.js",
},
module: {
loaders: [
{ test: /\.vue$/, loader: 'vue-loader' },
],
}
}
此配置将 index.js 指定为 webpack 的入口点,以确定要包含在 bundle.js 文件中的内容,该文件将被编译并放入 Vue 文件夹中。
为了在项目构建时编译 bundle.js 文件,我修改了项目文件以包含以下内容。
<Target Name="RunWebpack">
<Exec Command="npm install" />
<Exec Command="webpack" />
</Target>
<Target Name="BeforeBuild" DependsOnTargets="RunWebpack"></Target>
这将安装必要的 npm 包,然后运行 webpack 来构建 bundle.js。如果您在构建服务器上构建项目,这是必需的。
现在您只需要将 bundle.js 文件包含在一个 View 中,该 View 具有一个带有 #app
的元素。您不需要包含 vue.js 或 vue.min.js。那将在 bundle 中。
编译单个单个文件组件
我们发现有时我们想使用单个文件组件,但不想将其全部捆绑到一个脚本中。为此,您主要只需要修改 webpack.config.js。
const fs = require("fs");
const path = require("path");
// build an object that looks like
// {
// "filename": "./filename.vue"
// }
// to list the entry points for webpack to compile.
function buildEntry() {
const reducer = (entry, file) => { entry[file.split(".").shift()] = `./Vue/${file}`; return entry; };
return fs.readdirSync(path.join(__dirname, "Vue"))
.filter(file => file.endsWith(".vue"))
.reduce(reducer, {});
}
module.exports = {
entry: buildEntry(),
output: {
path: path.join(__dirname, "Vue"),
filename: "[name].js",
library: "[name]"
},
module: {
loaders: [
{ test: /\.vue$/, loader: 'vue-loader' },
],
}
}
此 webpack 配置将为每个单独的文件组件构建一个脚本文件。然后,您可以将该脚本包含在您使用上述“极其基本”技术的页面上,并通过全局公开或作为 Vue 的一部分在 Vue 中使用该组件。例如,如果我有一个 Modal.vue,我会在 ASP.NET MVC View 中包含 Modal.js,然后通过
将它暴露给 VueVue.component("Modal", Modal);
或
new Vue({
...
components:{
"Modal": Modal
}
})
Webpack 的可配置性很强,因此您可能希望采用不同的方法并为每个页面构建一个包。
最后,开发运行的时候可以打开命令行
webpack --watch
直接在您的项目中,您的包或单个组件将在您每次保存它们时构建。
关于asp.net-mvc - 在现有的多页 .NET MVC 应用程序中用 VueJS 2 替换 jQuery 的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42541315/
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!