谷粒学院(九)EasyExcel | 课程分类模块

2023-05-16

Excel导入导出的应用场景

1、数据导入:减轻录入工作量
2、数据导出:统计信息归档
3、数据传输:异构系统之间数据传输

一、EasyExcel简介

1、EasyExcel特点

Java领域解析、生成Excel比较有名的框架有Apache poi、jxl等。但他们都存在一个严重的问题就是非常的耗内存。如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc。

EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节省内存著称。EasyExcel能大大减少占用内存的主要原因是在解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。

EasyExcel采用一行一行的解析模式,并将一行的解析结果以观察者的模式通知处理(AnalysisEventListener)。

2、创建项目,实现EasyExcel对Excel写操作

1、pom中引入xml相关依赖

<dependencies>
    <!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>easyexcel</artifactId>
        <version>2.1.1</version>
    </dependency>
</dependencies>

还需要 poi 依赖

2、创建实体类

@Data
public class DemoData {
    //设置excel表头名称
    @ExcelProperty("学生编号")
    private Integer sno;

    @ExcelProperty("学生姓名")
    private String sname;
}

3、实现写操作

public class TestEasyExcel {
    public static void main(String[] args) {
        //实现excel写的操作
        //1 设置写入文件夹地址和excel文件名称
        String filename = "E:\\write.xlsx";

        //2 调用easyExcel里面的方法实现写操作
        //write方法两个参数,第一个参数文件路径名称,第二个参数实体类class
        EasyExcel.write(filename,DemoData.class).sheet("学生列表").doWrite(getData());
    }
    
    //创建方法返回list集合
    private static List<DemoData> getData(){
        List<DemoData> list = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            DemoData data = new DemoData();
            data.setSno(i);
            data.setSname("lucy"+i);
            list.add(data);
        }
        return list;
    }
}

3、创建项目,实现EasyExcel对Excel读操作

1、创建和excel对应实体类,标记对应列关系

@Data
public class DemoData {
    //设置excel表头名称
    @ExcelProperty(value = "学生编号",index = 0)
    private Integer sno;

    @ExcelProperty(value = "学生姓名",index = 1)
    private String sname;
}

2、创建监听进行excel文件读取

public class ExcelListener extends AnalysisEventListener<DemoData> {
    //一行一行读取excel内容
    @Override
    public void invoke(DemoData data, AnalysisContext analysisContext) {
        System.out.println("***"+data);
    }

    //读取表头内容
    @Override
    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
        System.out.println("表头"+headMap);
    }

    //读取完成之后
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) { }
}

3、最终测试

public static void main(String[] args) {
      //实现excel读的操作
       String filename = "E:\\write.xlsx";
       EasyExcel.read(filename,DemoData.class,new ExcelListener()).sheet().doRead();
}

二、课程分类后端添加功能

EasyExcel读取excel内容实现

1、引入easyexcel依赖

2、使用代码生成器把课程分类代码生成

3、创建实体类和excel对应关系

@Data
public class SubjectData {
    @ExcelProperty(index = 0)
    private String oneSujectName;

    @ExcelProperty(index = 1)
    private String twoSujectName;
}

4、编写 EduSubjectController 类

@Api(description = "课程分类")
@RestController
@RequestMapping("/eduservice/subject")
@CrossOrigin
public class EduSubjectController {

    @Autowired
    private EduSubjectService subjectService;

    //添加课程分类
    //获取上传的文件,把文件内容读取出来
    @ApiOperation(value = "添加课程分类")
    @PostMapping("addSubject")
    public R addSubject(MultipartFile file) {
        //上传过来excel文件
        subjectService.saveSubject(file,subjectService);
        return R.ok();
    }

}

5、编写 EduSubjectServiceImpl 类

@Service
public class EduSubjectServiceImpl extends ServiceImpl<EduSubjectMapper, EduSubject> implements EduSubjectService {

    //添加课程分类
    @Override
    public void saveSubject(MultipartFile file,EduSubjectService subjectService) {
        try {
            //文件输入流
            InputStream in = file.getInputStream();
            //调用方法进行读取
            EasyExcel.read(in,SubjectData.class,new SubjectExcelListener(subjectService)).sheet().doRead();
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

6、创建读取Excel监听器

public class SubjectExcelListener extends AnalysisEventListener<SubjectData> {

    //因为SubjectExcelListener不能交给Spring进行管理,需要自己new,不能注入其他对象
    //不能实现数据库操作
    private EduSubjectService subjectService;

    public SubjectExcelListener() {}
    public SubjectExcelListener(EduSubjectService subjectService) {
        this.subjectService = subjectService;
    }

    //一行一行去读取excle内容
    @Override
    public void invoke(SubjectData subjectData, AnalysisContext analysisContext) {
        if(subjectData == null) {
            throw new GuliException(20001,"文件数据为空");
        }
        //添加一级分类
        EduSubject existOneSubject = this.existOneSubject(subjectService,subjectData.getOneSujectName());
        if(existOneSubject == null) {//没有相同以及分类名称
            existOneSubject = new EduSubject();
            existOneSubject.setTitle(subjectData.getOneSujectName());//一级分类名称
            existOneSubject.setParentId("0");
            subjectService.save(existOneSubject);
        }

        //获取一级分类id值
        String pid = existOneSubject.getId();

        //添加二级分类
        EduSubject existTwoSubject = this.existTwoSubject(subjectService,subjectData.getTwoSujectName(), pid);
        if(existTwoSubject == null) {
            existTwoSubject = new EduSubject();
            existTwoSubject.setTitle(subjectData.getTwoSujectName());//二级分类
            existTwoSubject.setParentId(pid);
            subjectService.save(existTwoSubject);
        }
    }

    //判断一级分类是否重复
    private EduSubject existOneSubject(EduSubjectService subjectService,String name) {
        QueryWrapper<EduSubject> wrapper = new QueryWrapper<>();
        wrapper.eq("title",name);
        wrapper.eq("parent_id","0");
        EduSubject OneSubject = subjectService.getOne(wrapper);
        return OneSubject;
    }

    //判断二级分类是否重复
    private EduSubject existTwoSubject(EduSubjectService subjectService,String name,String pid) {
        QueryWrapper<EduSubject> wrapper = new QueryWrapper<>();
        wrapper.eq("title",name);
        wrapper.eq("parent_id",pid);
        EduSubject TwoSubject = subjectService.getOne(wrapper);
        return TwoSubject;
    }

    //读取excel表头信息
    @Override
    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
        System.out.println("表头信息:"+headMap);
    }

    //读取完成后执行
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {}

}

7、重启oss服务,Swagger中测试文件上传

http://localhost:8001/swagger-ui.html

三、课程分类前端添加功能

EasyExcel读取excel内容实现

1、添加课程分类路由

在/src/router/index.js中

{
 path: '/subject',
  component: Layout,
  redirect: '/subject/list',
  name: '课程分类管理',
  meta: { title: '课程分类管理', icon: 'example' },
  children: [
    {
      path: 'list',
      name: '课程分类列表',
      component: () => import('@/views/edu/subject/list'),
      meta: { title: '课程分类列表', icon: 'table' }
    },
    {
      path: 'save',
      name: '添加课程分类',
      component: () => import('@/views/edu/subject/save'),
      meta: { title: '添加课程分类', icon: 'tree' }
    }
  ]
},

在这里插入图片描述

2、创建课程分类页面,修改路由对应的页面路径

在这里插入图片描述

3、在添加课程分类页面 实现效果

添加上传组件实现

<template>
  <div class="app-container">
    <el-form label-width="120px">
      <el-form-item label="信息描述">
        <el-tag type="info">excel模版说明</el-tag>
        <el-tag>
          <i class="el-icon-download"/>
          <a :href="OSS_PATH + '/excel/%E8%AF%BE%E7%A8%8B%E5%88%86%E7%B1%BB%E6%A8%A1%E6%9D%BF.xls'">点击下载模版</a>
        </el-tag>

      </el-form-item>

      <el-form-item label="选择Excel">
        <el-upload
          ref="upload"
          :auto-upload="false"
          :on-success="fileUploadSuccess"
          :on-error="fileUploadError"
          :disabled="importBtnDisabled"
          :limit="1"
          :action="BASE_API+'/eduservice/subject/addSubject'"
          name="file"
          accept="application/vnd.ms-excel">
          <el-button slot="trigger" size="small" type="primary">选取文件</el-button>
          <el-button
            :loading="loading"
            style="margin-left: 10px;"
            size="small"
            type="success"
            @click="submitUpload">{{ fileUploadBtnText }}</el-button>
        </el-upload>
      </el-form-item>
    </el-form>
  </div>
</template>

js上传方法

<script>
export default {
    data() {
        return {
            BASE_API: process.env.BASE_API, // 接口API地址
            OSS_PATH: process.env.OSS_PATH,// 阿里云OSS地址
            fileUploadBtnText: '上传到服务器',//按钮文字
            importBtnDisabled: false, // 按钮是否禁用,
            loading: false
        }
    },
    created() {

    },
    methods:{
        //点击按钮上传文件到接口里面
        submitUpload() {
            this.importBtnDisabled = true
            this.loading = true
            // js: document.getElementById("upload").submit()
            this.$refs.upload.submit()
        },
        //上传成功
        fileUploadSuccess(response) {
            //提示信息
            this.loading = false
            this.$message({
                type: 'success',
                message: '添加课程分类成功'
            })
            //跳转课程分类列表
            //路由跳转
            this.$router.push({path:'/subject/list'})
        },
        //上传失败
        fileUploadError() {
            this.loading = false
            this.$message({
                type: 'error',
                message: '添加课程分类失败'
            })
        }
    }
}
</script>

在这里插入图片描述

4、启动服务测试

四、课程分类列表后端(树形)

1、根据返回数据创建对应实体类

一级分类

@Data
public class OneSubject {
    private String id;
    private String title;

    //一个一级分类里面有多个二级分类
    private List<TwoSubject> children = new ArrayList<>();
}

二级分类

@Data
public class TwoSubject {
    private String id;
    private String title;
}

返回数据格式为:
在这里插入图片描述

2、编写Controller类

//课程分类列表
@ApiOperation(value = "课程分类列表")
@GetMapping("getAllSubject")
public R getAllSubject(){
    //list集合泛型是一级分类
    List<OneSubject> list = subjectService.getAllOneTwoSubject();
    return R.ok().data("list",list);
}

3、编写Service类

//课程分类列表(树形)
@Override
public List<OneSubject> getAllOneTwoSubject() {
    //1 查询所有一级分类   parent_id = 0
    QueryWrapper<EduSubject> wrapperOne = new QueryWrapper<>();
    wrapperOne.eq("parent_id",0);
    List<EduSubject> oneSubjectList = baseMapper.selectList(wrapperOne);

    //2 查询所有二级分类   parent_id != 0
    QueryWrapper<EduSubject> wrapperTwo = new QueryWrapper<>();
    wrapperTwo.ne("parent_id",0);
    List<EduSubject> twoSubjectList = baseMapper.selectList(wrapperTwo);

    //创建list集合,用于存储最终封装数据
    List<OneSubject> finalSubjectList = new ArrayList<>();

    //3 封装一级分类
    //查询出来所有一级分类list集合集合,得到每一个一级分类对象,回去每一个一级分类对象值,
    //封装到要求的list集合里面  List<OneSubject> findSubjectList
    for (int i = 0; i < oneSubjectList.size(); i++) {//遍历oneSubjectList集合
        //得到oneSubjectList每个eduSubject对象
        EduSubject eduSubject = oneSubjectList.get(i);

        //把eduSubject里面值获取出来,放到OneSubject对象里面
        //多个OneSubject放到findSubjectList里面
        OneSubject oneSubject = new OneSubject();
//            oneSubject.setId(eduSubject.getId());
//            oneSubject.setTitle(eduSubject.getTitle());

        //把eduSubject里面获取出来的值,放到oneSubject对象里面
        BeanUtils.copyProperties(eduSubject,oneSubject);
        //多个OneSubject放到findSubjectList里面
        finalSubjectList.add(oneSubject);

        //在一级分类循环遍历查询所有的二级分类
        //创建list集合封装每一个一级分类的二级分类
        List<TwoSubject> twoFinalSubjectList = new ArrayList<>();
        //遍历二级分类list集合
        for (int m = 0; m < twoSubjectList.size(); m++) {
            //获取每个二级分类list集合
            EduSubject tSubject = twoSubjectList.get(m);
            //判断二级分类parentid和一级分类id是否一样
            if(tSubject.getParentId().equals(eduSubject.getId())) {
                //把tSubject值复制到TwoSubject里面,放到twoFinalSubjectList里面
                TwoSubject twoSubject = new TwoSubject();
                BeanUtils.copyProperties(tSubject,twoSubject);
                twoFinalSubjectList.add(twoSubject);
            }
        }
        //把一级下面所有二级分类放到一级分类里面
        oneSubject.setChildren(twoFinalSubjectList);
    }

    return finalSubjectList;
}

4、使用swagger进行测试

五、课程分类列表前端

1、参考tree模块把前端整合出来

<template>
  <div class="app-container">
    <el-input v-model="filterText" placeholder="Filter keyword" style="margin-bottom:30px;" />

    <el-tree
      ref="tree2"
      :data="data2"
      :props="defaultProps"
      :filter-node-method="filterNode"
      class="filter-tree"
      default-expand-all
    />

  </div>
</template>

2、对应的js文件

<script>
import subject from '@/api/edu/subject'
export default {

  data() {
    return {
      filterText: '',
      data2: [],//返回所有分类数据
      defaultProps: {
        children: 'children',
        label: 'title'
      }
    }
  },
  created() {
    this.getAllSubjectList()
  },
  watch: {
    filterText(val) {
      this.$refs.tree2.filter(val)
    }
  },

  methods: {
    getAllSubjectList(){
      subject.getSubjectList()
        .then(response => {
          this.data2 = response.data.list
        })
    },
    filterNode(value, data) {
      if (!value) return true
      return data.title.toLowerCase().indexOf(value) !== -1
    }
  }
}
</script>

3、前端接口调用

import request from '@/utils/request'

export default{
    //课程分类列表
    getSubjectList(){
        return request({
            url: `/eduservice/subject/getAllSubject`,
            method: 'get'
        })
    }
}

4、启动项目服务测试


如果有收获!!! 希望老铁们来个三连,点赞、收藏、转发。
创作不易,别忘点个赞,可以让更多的人看到这篇文章,顺便鼓励我写出更好的博客
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

谷粒学院(九)EasyExcel | 课程分类模块 的相关文章

  • easyexcel读取合并单元格

    easyexcel读取合并单元格 文章目录 easyexcel读取合并单元格一 设置读取额外信息二 重写Listener中的extra 方法 xff0c 获取合并单元格的信息三 遍历合并单元格的信息四 代码清单1 UploadDataLis
  • java中使用easyexcel框架自定义格式写入excel

    一般的excel示例 xff0c 都是写入列表数据到excel xff0c 格式上有表头 xff0c 内容使用List集合来填充 今天遇到的需求有点不一样 xff0c 它也是需要写入excel xff0c 但是开头的内容并不是列表 xff0
  • 谷粒学院(一)项目介绍

    一 项目背景 在线教育顾名思义 xff0c 是以网络为介质的教学方式 xff0c 通过网络 xff0c 学员与教师即使相隔万里也可以开展教学活动 xff0c 此外 xff0c 借助网络课件 xff0c 学员还可以随时随地进行学习 xff0c
  • 谷粒学院(二十二)spring security | 权限管理 | 权限整合springsecurity

    文章目录 一 权限管理需求描述1 菜单管理2 角色管理3 用户管理4 表与表之间的关系 二 spring security介绍1 框架介绍2 认证与授权实现思路 三 整合spring security1 复制工具类到common utils
  • 谷粒学院(二十三)配置中心nacos

    一 配置中心介绍 1 Spring Cloud Config Spring Cloud Config 为分布式系统的外部配置提供了服务端和客户端的支持方案 在配置的服务端您可以在所有环境中为应用程序管理外部属性的中心位置 客户端和服务端概念
  • 谷粒学院-项目功能模块、技术点、整合Mybatis-Plus、主键生成策略

    Mybaitis Plus 简介 MyBatis Plus 初始化工程 使用 Spring Initializr 快速初始化一个 Spring Boot 工程 Group xff1a com nanjing Artifact xff1a m
  • EasyExcel读取多个Sheet页数据

    使用EasyExcel一次性读取多个sheet页 通过EasyExcel readSheet方法指定读取sheet页的下标 这里的sheet下标是从0开始的 可通过headRowNumber指定从哪一行开始读取 下标也是从0开始 如果表头是
  • 基于EasyExcel的Excel读取

    1 引入依赖
  • Springboot整合easyExcel

    Springboot整合easyExcel 介绍 Entity实体类 下载模板 上传Excel文件 上传Excel 前端页面 测试 介绍 平时工作中 我们经常都会用到excel文件上传或者下载的问题 比如将表数据导出为excel表格或者进行
  • EasyExcel导出模板实现下拉选(解决下拉超过50个限制)

    学习地址 https d9bp4nr5ye feishu cn wiki O3obweIbgi2Rk1ksXJncpClTnAf B站视频 https www bilibili com video BV1H34y1T7Lm 先来看看最终实现
  • Easyexcel 导出数据 一对多关系导出数据集合

    客户要求 要求导出的表格如图 实现这样表格 很多人会想到动态表头 easypoi可以直接实现 但是我用的是easyexcel 而easyexcel自身并没有提供自动合并的功能所以还是需要自己来合并 代码如下 首先我们来看下将嵌套数据平铺 不
  • 记录工作中使用easyExcel实现复杂一对多excel表格导出及多sheet页导出

    业务场景 一个工单对应多个项目 一个项目对应多个配件信息 这样形成了三层级联的一对多的业务场景 实现效果如下 功能实现 1 引入maven
  • easyexcel poi 一个模板导出excel包含多个sheet

    easy poi 一个模板导出excel包含多个sheet 1 简述 2 导出代码实例 3 导出模板 4 导出效果 5 项目实战案例 1 简述 通过调用ExcelExportUtil exportExcelClone map params
  • easyExcel实现excel文件上传和下载

    一 easyExcel简介 在工作中 经常需要把excel中的数据导入系统 亦或是把系统中符合筛选条件的数据通过excel的方式导出 Java解析 生成Excel比较有名的框架有Apache poi jxl 但他们都存在一个严重的问题就是非
  • 使用EasyExcel添加Excel数据

    一 导入excel代码 1 pom文件
  • Excel转CSV格式

    注意 CSV文件导出来的 可以理解为 就是一个 普通的文件 但至于使用什么样的软件打开就是另一马事了 比如Excel打开后 出来 自动过滤了数字前面的0 这玩意程序控制不到 那是Excel的事情 CSV不是Excel文件切记 只不过用表格软
  • easyexcel poi 指定行指定列设置样式

    easyexcel poi 指定行指定列设置样式 1 给指定行指定列设置字体及居中 2 给指定行指定列设置边框 1 给指定行指定列设置字体及居中 给指定行指定列设置字体及居中 param workbook param rowIndex 第几
  • easyExcel日期字符串格式统一处理

    1 遇到日期导入转换Date失败情况 excel里面日期是字符串 java实体类和数据库都是日期类型 导入转换 public class EasyExcelString2DateConvert implements Converter
  • Java 使用EasyExcel解析导入的Excel文件

    最近在做项目时 有遇到需要使用excel导入的场景 以前也有写过使用 Apache poi 来解析导入数据 但整体解析逻辑比较繁琐 封装成工具类后也不是很好用 这个可能是我个人技术原因 和poi无关 这次开发时 在网上找了个更加简洁的方式
  • 谷粒学院——Day09【整合阿里云视频点播】

    作者主页 Java技术一点通的博客 个人介绍 大家好 我是Java技术一点通 记得关注 点赞 收藏 评论 认真学习 共同进步 视频点播简介 一 阿里云视频点播技术能力盘点 视频点播 ApsaraVideo for VoD 是集音视频采集 编

随机推荐

  • jsp和servlet的区别

    基本介绍 Servlet xff1a Servlet 是一种服务器端的Java应用程序 xff0c 具有独立于平台和协议的特性 xff0c 可以生成动态的Web页面 它担当客户请求 xff08 Web浏览器或其他HTTP客户程序 xff09
  • Session学习笔记

    1 session 简介 session 是我们 jsp 九大隐含对象的一个对象 session 称作域对象 xff0c 他的作用是保存一些信息 xff0c 而 session 这个域对象是一次会话期间使用同一个对象 所以这个对象可以用来保
  • session和cookie 区别【面试】

    说说Cookie和Session的区别 xff1f 1 存取方式的不同 xff08 Cookie只能保存ASCII xff0c Session可以存任意数据类型 xff09 Cookie中只能保管ASCII字符串 xff0c 假如需求存取U
  • JSP 九大内置对象,四大域对象

    JSP的九大内置对象 内置对象名 类型 request HttpServletRequest response HttpServletResponse session HttpSession application ServletConte
  • SpringCloud(八)Hystrix断路器

    文章目录 1 概述分布式系统面临的问题是什么能干嘛官网资料Hystrix官宣 xff0c 停更进维 2 Hystrix重要概念3 hystrix案例构建项目高并发测试故障现象和导致原因上诉结论如何解决 xff1f 解决的要求服务降级服务熔断
  • 谷粒学院(一)项目介绍

    一 项目背景 在线教育顾名思义 xff0c 是以网络为介质的教学方式 xff0c 通过网络 xff0c 学员与教师即使相隔万里也可以开展教学活动 xff0c 此外 xff0c 借助网络课件 xff0c 学员还可以随时随地进行学习 xff0c
  • PyTorch:Dataset()与Dataloader()的使用详解

    目录 1 Dataset类的使用 2 Dataloader类的使用 3 总结 Dataset类与Dataloader类是PyTorch官方封装的用于在数据集中提取一个batch的训练用数据的接口 xff0c 其实我们也可以自定义获取每个ba
  • MyBatisPlus(二)入门案例

    一 快速入门 使用第三方组件 xff1a 导入对应的依赖研究依赖如何配置代码如何编写提高扩展技术能力 操作步骤 1 创建数据库mybatis plus 2 创建user表 span class token keyword DROP span
  • MyBatisPlus(三)CRUD接口操作

    一 CRUD扩展 Insert 插入 span class token comment 测试插入 span span class token annotation punctuation 64 Test span span class to
  • MyBatisPlus(四)性能分析插件 | 条件构造器 | 代码生成器

    文章目录 一 性能分析插件1 导入插件2 测试使用 二 条件构造器1 ge gt le It isNull isNotNull2 eq ne3 between notBetween4 like noLike likeLeft likeRig
  • 谷粒学院(三)讲师管理模块后端 | swagger | 统一日志 | 统一返回结果

    文章目录 一 讲师查询功能二 讲师逻辑删除功能三 配置Swagger2四 统一返回数据格式五 创建统一结果返回类六 统一返回结果使用七 讲师分页查询八 讲师条件查询带分页九 自动填充封装十 讲师添加功能十一 讲师修改功能十二 统一异常处理十
  • 谷粒学院(二)项目搭建

    一 讲师管理模块 xff08 后端 xff09 准备工作 1 创建数据库 xff0c 创建讲师数据库 guli edu sql 2 模块说明 guli parent xff1a 在线教学根目录 xff08 父工程 xff09 xff0c 管
  • 谷粒学院(四)前端开发之ES6 | Vue

    文章目录 一 VSCode的安装及创建二 ES6简介三 ES6基本语法1 let声明变量2 const声明常量 xff08 只读变量 xff09 3 解构赋值4 模板字符串5 声明对象简写6 定义方法简写7 对象拓展运算符8 箭头函数 四
  • 谷粒学院(五)前端知识 nodejs | npm | babel | 模块化 | webpack

    一 nodejs 1 Node js是什么 简单的说 Node js 就是运行在服务端的 JavaScript Node js是一个事件驱动I O服务端JavaScript环境 xff0c 基于Google的V8引擎 xff0c V8引擎执
  • 系统上禁止运行脚本。有关详细信息, 请参阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies

    babel 无法加载文件 D studysoft nodejs babel ps1 xff0c 因为在此系统上禁止运行脚本 有关详细信息 xff0c 请参阅 https go microsoft com fwlink LinkID 61 1
  • 谷粒学院(六)前端页面搭建说明 | vue-element-admin

    文章目录 一 vue element admin1 简介2 安装 二 前端页面环境说明1 前端框架入口2 前端页面使用框架模板 xff0c 主要基于两种技术实现出来3 目录结构介绍 三 项目的创建和基本配置1 创建项目2 修改项目信息3 如
  • 谷粒学院(七)讲师列表前端实现

    一 讲师查询功能 1 添加路由 在 src router index js中 span class token punctuation span path span class token punctuation span span cla
  • Windows10:耳机插到前面板上没声音?

    今天买了副新耳机 xff0c 正开心地插到台式机的前面板接口上 xff0c 结果伤心地发现他竟然没声音T T xff0c 但是在手机上试一下还是能用的 xff01 折腾了好一会才发现问题的所在 xff01 耳机没声音有好多种情况 xff0c
  • 谷粒学院(八)阿里云oss | 头像上传 | Nginx

    文章目录 一 阿里云oss存储服务1 开通 对象存储OSS 服务2 进入oss管理控制台3 Java代码操作阿里云oss上传文件 二 后端集成OSS1 在service模块下创建子模块 96 service oss 96 2 配置pom x
  • 谷粒学院(九)EasyExcel | 课程分类模块

    Excel导入导出的应用场景 1 数据导入 xff1a 减轻录入工作量 2 数据导出 xff1a 统计信息归档 3 数据传输 xff1a 异构系统之间数据传输 一 EasyExcel简介 1 EasyExcel特点 Java领域解析 生成E