【Vue】Java后端程序员也必须掌握的前端框架(下)(一)

简介: 【Vue】Java后端程序员也必须掌握的前端框架(下)

前言


本文为Vue框架基础知识、语法与使用介绍,Java全栈学习路线可参考:【Java全栈学习路线】最全的Java学习路线及知识清单,Java自学方向指引,内含最全Java全栈学习技术清单~

本文上接:【Vue】Java后端程序员也必须掌握的前端框架(上)


十一、自定义事件内容分发

<div id="app">
<todo>
<todo-title slot="todo-title" v-bind:title="title"></todo-title>
<todo-items slot="todo-items" v-for="{item,index} in todoItems" :item="item" v-bind:index="index" v-on:remove="removeItems(index)" v-bind:key="index"></todo-items>
</todo>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"> </script>
<script>
// 定义一个待办事项的组件
//插槽
Vue.component(‘todo’, {
template:
‘<div>\
<slot name="todo-title"></slot>\
<ul>\
<solt name="todo-items"></solt>\
</ul>\
</div>‘
});
Vue.component(“todo-title”,{
props: [‘title’],
template: ‘<div>{ {title} }</div>‘
});
Vue.component(“todo-items”,{
props: [‘item’,’index’],
//只能绑定当前组件的方法
template: ‘<li>{ {item} }<button @click="remove">删除</button></li>‘,
methods:{
remove:function (index) {
//自定义事件并发
this.$emit(‘remove’, index);
}
}
});
var vm = new Vue({
el:”#app”,
data:{
title:’kaungshen’,
todoItems:[‘狂神说’,’java’]
},
methods: {
removeItems:function (index) {
console.log(“删除了”+this.todoItems[index]+”OK”);
this.todoItems.splice(index,1);
}
}
});
</script>


十二、vue-cli


  • vue-cli 官方提供的一个脚手架,用于快速生成一个 vue 的项目模板


1.安装 vue-cli

cnpm install vue-cli -g
# 测试是否安装成功
# 查看可以基于哪些模板创建 vue 应用程序,通常我们选择 webpack
vue list


2.第一个 vue-cli 应用程序

1、我们新建一个文件夹 vue-cli;
2、创建一个基于 webpack 模板的 vue 应用程序
# 这里的 myvue 是项目名称,可以根据自己的需求起名
vue init webpack myvue
# 一路都选择no即可;
Project name:项目名称,默认 回车 即可
Project description:项目描述,默认 回车 即可
Author:项目作者,默认 回车 即可
Install vue-router:是否安装 vue-router,选择 n 不安装(后期需要再手动添加)
Use ESLint to lint your code:是否使用 ESLint 做代码检查,选择 n 不安装(后期需要再手动添
加)
Set up unit tests:单元测试相关,选择 n 不安装(后期需要再手动添加)
Setup e2e tests with Nightwatch:单元测试相关,选择 n 不安装(后期需要再手动添加)
Should we run npm install for you after the project has been created:创建完成后直接初始
化,选择 n,我们手动执行;运行结果!
初始化并运行
cd myvue
npm install
npm run dev


3.Vue-cli目录结构


build 和 config:WebPack 配置文件

node_modules:用于存放 npm install 安装的依赖文件

src: 项目源码目录

static:静态资源文件

.babelrc:Babel 配置文件,主要作用是将 ES6 转换为 ES5

.editorconfig:编辑器配置

eslintignore:需要忽略的语法检查配置文件

.gitignore:git 忽略的配置文件

.postcssrc.js:css 相关配置文件,其中内部的 module.exports 是 NodeJS 模块化语法

index.html:首页,仅作为模板页,实际开发时不使用

package.json:项目的配置文件

name:项目名称

version:项目版本

description:项目描述

author:项目作者

scripts:封装常用命令

dependencies:生产环境依赖

devDependencies:开发环境依赖


项目的入口文件:


import Vue from ‘vue’
import App from ‘./App’
Vue.config.productionTip = false;
/ eslint-disable no-new /
new Vue({
el: ‘#app’,
components: { App },
template: ‘<App/>‘
});
/*
import Vue from ‘vue’ :ES6 写法,会被转换成 require(“vue”);(require 是 NodeJS 提供的模块加载器)
import App from ‘./App’ :意思同上,但是指定了查找路径,./ 为当前目录
Vue.config.productionTip = false :关闭浏览器控制台关于环境的相关提示
new Vue({…}) :实例化 Vue
el: ‘#app’ :查找 index.html 中 id 为 app 的元素
template: ‘’ :模板,会将 index.html 中替换为
components: { App } :引入组件,使用的是 import App from ‘./App’ 定义的 App 组 件;
*/


App.vue

<template>
<div id="app">
<img src="./assets/logo.png">
<HelloWorld/>
</div>
</template>
<script>
import HelloWorld from ‘./components/HelloWorld’
export default {
name: ‘App’,
components: {
HelloWorld
}
}
</script>
<style>
#app {
font-family: ‘Avenir’, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>
/*
template:HTML 代码模板,会替换 < App /> 中的内容
import HelloWorld from './components/HelloWorld':引入 HelloWorld 组件用于替换 template
中的 < HelloWorld/>
export default{...}:导出 NodeJS 对象,作用是可以通过 import 关键字导入
   name: 'App':定义组件的名称
   components: { HelloWorld }:定义子组件
在hello,Vue中,关于 < style scoped> 的说明:CSS 样式仅在当前组件有效,声明了样式的作用域,
是当前的界面私有的!
*/


十三、Vue的Webpack


安装Webpack


npm install webpack -g
npm install webpack-cli -

测试安装成功


webpack -v
webpack-cli -

使用webpack


1.创建项目

2.创建一个名为modules的目录,用于放置JS模块等资源文件

3.在modules下创建模块文件,如hello.js用于编写JS模块相关代码

如:

/暴露一个方法/

exports.sayHi = function () {
document.write(“<h1>java</h1>“)
}

4.在modules下创建一个名为main.js的入口文件用于打包设置entry属性

如:

var hello = require(“./hello”);
hello.sayHi();

5.在项目目录下创建webpack.config.js配置文件,使用webpack命令打包webpack

6.在主页面引入打包之后的js文件

webpack.config.js模板

module.exports = {
entry:””,//入口文件
output:{//输出,指定WebPack把处理完成的文件放置到指定路径
path:””,
filename:””
},
module:{//模块,用于处理各种类型的文件
loaders:[
{test:/.js$/,loader:””}
]
},
plugins:{},插件,如:热更新,代码重用等
resolve:{},//指定路径指向
watch:true//监听,用于设置文件改动后直接打包
}

十四、vue-router路由


安装


npm install vue-router --save-dev


Vue的原理

1、 components 目录下存放我们自己编写的组件

2、定义组件 Content.vue 组件

    <template> 
        <div> 
            <h1>内容页</h1> 
        </div> 
    </template> 
    <script> 
        export default { 
            name: "Content" 
        }
    </script>

3、安装路由,在src目录下,新建一个文件夹 : router ,专门存放路由,写入 index.js

    import Vue from 'vue' 
    // 导入路由插件 
    import Router from 'vue-router' 
    // 导入上面定义的组件 
    import Content from '../components/Content' 
    // 安装路由 
    Vue.use(Router); 
    // 配置路由 
    export default new Router({ 
        routes: [ 
            { 
                // 路由路径 
                path: '/content', 
                // 路由名称 
                name: 'content', 
                // 跳转到组件 
                component: Content 
            } 
        ] 
    });


4、我们在新建一个 Main.vue 组件

<template> 
    <div> 
        <h1>首页</h1> 
    </div> 
</template> 
<script> 
    export default { 
        name: "Main" 
    }
</script>

5、将Main组件也配置到路由中!

import Main from '../components/Main'
{ 
    // 路由路径 
    path: '/main', 
    // 路由名称 
    name: 'main', 
    // 跳转到组件 
    component: Main 
}

6、在 main.js 中配置路由

import Vue from 'vue' 
import App from './App' 
// 导入上面创建的路由配置目录 
import router from './router' 
Vue.config.productionTip = false 
new Vue({ 
    el: '#app', 
    // 配置路由 
    router, 
    components: { App }, 
    template: '<App/>' 
})

7、在 App.vue 中使用路由

<template> 
    <div id="app"> 
    <router-link to="/main">首页</router-link> 
    <router-link to="/content">内容</router-link> <router-view></router-view> 
    </div> 
</template>

调用过程

main.js–>App.vue
main.js–>index.js(路由设置)
App.vue–>其他按照路由vue
index.js–>引入其他vue
相关文章
|
23天前
|
存储 算法 Java
惊!Java程序员必看:JVM调优揭秘,堆溢出、栈溢出如何巧妙化解?
【8月更文挑战第29天】在Java领域,JVM是代码运行的基础,但需适当调优以发挥最佳性能。本文探讨了JVM中常见的堆溢出和栈溢出问题及其解决方法。堆溢出发生在堆空间不足时,可通过增加堆空间、优化代码及释放对象解决;栈溢出则因递归调用过深或线程过多引起,调整栈大小、优化算法和使用线程池可有效应对。通过合理配置和调优JVM,可确保Java应用稳定高效运行。
101 4
|
27天前
|
Java 程序员
Java数据类型:为什么程序员都爱它?
Java数据类型:为什么程序员都爱它?
39 1
|
25天前
|
前端开发 JavaScript API
解锁高效应用构建:Vuex与后端交互的前端状态同步策略,让数据流动如行云流水,紧跟前端开发的热点趋势
【8月更文挑战第27天】本文深入探讨了Vue框架下的前端状态管理库Vuex与后端服务交互时的状态同步策略。通过剖析Vuex的核心机制——状态(State)、变异(Mutation)、动作(Action)及模块(Module),文章展示了如何优雅地将后端数据加载并更新至前端状态中。特别地,借助示例代码解释了Action处理API调用、Mutation更新状态的过程,并介绍了如何通过模块化和命名空间提高状态管理的准确性和时效性。此外,还讨论了组件如何利用`mapState`和`mapActions`简化状态访问与操作的方法。遵循这些策略,开发者可以在构建复杂应用时显著提升性能与用户体验。
31 0
|
2天前
|
机器学习/深度学习 数据采集 JavaScript
ADR智能监测系统源码,系统采用Java开发,基于SpringBoot框架,前端使用Vue,可自动预警药品不良反应
ADR药品不良反应监测系统是一款智能化工具,用于监测和分析药品不良反应。该系统通过收集和分析病历、处方及实验室数据,快速识别潜在不良反应,提升用药安全性。系统采用Java开发,基于SpringBoot框架,前端使用Vue,具备数据采集、清洗、分析等功能模块,并能生成监测报告辅助医务人员决策。通过集成多种数据源并运用机器学习算法,系统可自动预警药品不良反应,有效减少药害事故,保障公众健康。
ADR智能监测系统源码,系统采用Java开发,基于SpringBoot框架,前端使用Vue,可自动预警药品不良反应
|
20天前
|
前端开发 Java Spring
Spring与Angular/React/Vue:当后端大佬遇上前端三杰,会擦出怎样的火花?一场技术的盛宴,你准备好了吗?
【8月更文挑战第31天】Spring框架与Angular、React、Vue等前端框架的集成是现代Web应用开发的核心。通过RESTful API、WebSocket及GraphQL等方式,Spring能与前端框架高效互动,提供快速且功能丰富的应用。RESTful API简单有效,适用于基本数据交互;WebSocket支持实时通信,适合聊天应用和数据监控;GraphQL则提供更精确的数据查询能力。开发者可根据需求选择合适的集成方式,提升用户体验和应用功能。
52 0
|
20天前
|
前端开发 Java JSON
Struts 2携手AngularJS与React:探索企业级后端与现代前端框架的完美融合之道
【8月更文挑战第31天】随着Web应用复杂性的提升,前端技术日新月异。AngularJS和React作为主流前端框架,凭借强大的数据绑定和组件化能力,显著提升了开发动态及交互式Web应用的效率。同时,Struts 2 以其出色的性能和丰富的功能,成为众多Java开发者构建企业级应用的首选后端框架。本文探讨了如何将 Struts 2 与 AngularJS 和 React 整合,以充分发挥前后端各自优势,构建更强大、灵活的 Web 应用。
35 0
|
20天前
|
前端开发 开发者 UED
数据校验的艺术:揭秘JSF如何将前端与后端验证合二为一,打造无缝用户体验
【8月更文挑战第31天】JavaServer Faces(JSF)是构建企业级Web应用的Java规范,提供了丰富的组件和API,便于快速搭建用户界面。JSF验证框架基于JavaBean验证API(JSR 303/JSR 380),利用注解如`@NotNull`、`@Size`等在模型类上定义验证规则,结合前端的`&lt;h:inputText&gt;`和`&lt;h:message&gt;`标签展示错误信息。
23 0
|
20天前
|
前端开发 大数据 数据库
🔥大数据洪流下的决战:JSF 表格组件如何做到毫秒级响应?揭秘背后的性能魔法!💪
【8月更文挑战第31天】在 Web 应用中,表格组件常用于展示和操作数据,但在大数据量下性能会成瓶颈。本文介绍在 JavaServer Faces(JSF)中优化表格组件的方法,包括数据处理、分页及懒加载等技术。通过后端分页或懒加载按需加载数据,减少不必要的数据加载和优化数据库查询,并利用缓存机制减少数据库访问次数,从而提高表格组件的响应速度和整体性能。掌握这些最佳实践对开发高性能 JSF 应用至关重要。
36 0
|
20天前
|
前端开发 开发者 Apache
揭秘Apache Wicket项目结构:如何打造Web应用的钢铁长城,告别混乱代码!
【8月更文挑战第31天】Apache Wicket凭借其组件化设计深受Java Web开发者青睐。本文详细解析了Wicket项目结构,帮助你构建可维护的大型Web应用。通过示例展示了如何使用Maven管理依赖,并组织页面、组件及业务逻辑,确保代码清晰易懂。Wicket提供的页面继承、组件重用等功能进一步增强了项目的可维护性和扩展性。掌握这些技巧,能够显著提升开发效率,构建更稳定的Web应用。
53 0
|
21天前
|
存储 设计模式 运维
Angular遇上Azure Functions:探索无服务器架构下的开发实践——从在线投票系统案例深入分析前端与后端的协同工作
【8月更文挑战第31天】在现代软件开发中,无服务器架构因可扩展性和成本效益而备受青睐。本文通过构建一个在线投票应用,介绍如何结合Angular前端框架与Azure Functions后端服务,快速搭建高效、可扩展的应用系统。Angular提供响应式编程和组件化能力,适合构建动态用户界面;Azure Functions则简化了后端逻辑处理与数据存储。通过具体示例代码,详细展示了从设置Azure Functions到整合Angular前端的全过程,帮助开发者轻松上手无服务器应用开发。
10 0