正则采集器之四——采集网站管理

本文介绍正则采集器的采集网站管理的开发。

系统需要动态添加采集网站,对网站地址、名称、匹配商品的正则表达式字段进行设置。

新建数据库表

CREATE TABLE `item_website` (`id` bigint NOT NULL AUTO_INCREMENT,`code` varchar(16) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,`name` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,`url` varchar(512) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,`regexp_str` varchar(512) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,`regexp_contents` varchar(2048) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,`start_str` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,`end_str` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

后端代码

在后端代码中新建实体类、Mapper类和Controller类,下面贴出Controller类,因为采集网站不会非常多,所以不分页。请求地址和参数采用REST风格编写。

package com.learn.reptile.web.controller;import java.util.List;import javax.annotation.Resource;import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.learn.reptile.entity.po.ItemWebsite;
import com.learn.reptile.entity.vo.R;
import com.learn.reptile.mapper.ItemWebsiteMapper;@RequestMapping("/itemWebsite")
@RestController
public class ItemWebsiteController {@ResourceItemWebsiteMapper itemWebsiteMapper;@GetMappingpublic R<List<ItemWebsite>> list() {return R.ok(itemWebsiteMapper.selectList(new QueryWrapper<>()));}@GetMapping("{id}")public R get(@PathVariable("id") Long id) {return R.ok(itemWebsiteMapper.selectById(id));}@PostMappingpublic R add(@RequestBody ItemWebsite itemWebsite) {itemWebsiteMapper.insert(itemWebsite);return R.ok();}@PutMapping("{id}")public R update(@PathVariable("id") Long id, @RequestBody ItemWebsite itemWebsite) {itemWebsiteMapper.updateById(itemWebsite);return R.ok();}@DeleteMapping("{id}")public R deleteById(@PathVariable("id") Long id) {itemWebsiteMapper.deleteById(id);return R.ok();}
}

前端代码

添加router,位置:src/router/modules/home.js

{path: '/item', //父菜单,下面还会加其他菜单component: Layout,name: 'item',meta: {title: '商品',},icon: 'icon-home',children: [{path: 'itemWebsite',name: 'itemWebiste',component: () => import('@/views/item_website/index.vue'),meta: {title: '网站',},},],},

添加api,位置:src/api/itemWebsite.js

import request from '@/utils/request'export const add = data => {return request({url: '/api/itemWebsite',method: 'post',data,})
}export const update = data => {return request({url: '/api/itemWebsite/' + data.id,method: 'put',data,})
}export const deleteById = id => {return request({url: '/api/itemWebsite/' + id,method: 'delete',})
}export const list = () => {return request({url: '/api/itemWebsite',method: 'get',})
}export const getById = id => {return request({url: '/api/itemWebsite/' + id,method: 'get',})
}

添加页面,位置src/views/item_website/index.vue

<template><div><el-button type="primary" @click="edit(null)">添加</el-button><el-table:data="list"v-loading="loading"element-loading-text="Loading"highlight-current-rowborderfit><el-table-column prop="code" label="编码"></el-table-column><el-table-column prop="name" label="名称"></el-table-column><el-table-column label="操作"><template #default="scope"><el-buttontype="primary"@click="$router.push('/item/itemRegexp/' + scope.row.id)">商品匹配规则</el-button><el-button @click="edit(scope.row)">修改</el-button><el-popconfirm title="确认删除?" @confirm="deleteById(scope.row.id)"><template #reference><el-button type="danger">删除</el-button></template></el-popconfirm></template></el-table-column></el-table><el-dialogv-model="editDialogVisible":title="editForm.id ? '修改网站' : '添加网站'"width="40%"@close="editDialogVisible = false"><el-formref="editFormRef":model="editForm":rules="editFormRules"label-position="left"><el-form-item prop="code" label="编码"><el-input v-model="editForm.code"></el-input></el-form-item><el-form-item prop="name" label="名称"><el-input v-model="editForm.name"></el-input></el-form-item><el-form-item prop="url" label="URL"><el-input v-model="editForm.url"></el-input></el-form-item><el-form-item><el-button type="primary" @click="save">保存</el-button><el-button type="warning" @click="editDialogVisible = false">取消</el-button></el-form-item></el-form></el-dialog></div>
</template><script>
import {getCurrentInstance,reactive,toRefs,ref,computed,watch,onMounted,
} from 'vue'
import { list, add, update, deleteById } from '@/api/itemWebsite'export default {setup() {const { proxy: ctx } = getCurrentInstance()const state = reactive({loading: false,list: [],editDialogVisible: false,editForm: {id: '',code: '',name: '',url: '',},editFormRules: {code: [{ required: true, message: '编码不能为空' }],name: [{ required: true, message: '名称不能为空' }],url: [{ required: true, message: 'URL不能为空' }],},editFormRef: ref(null),save() {ctx.$refs.editFormRef.validate(valid => {if (valid) {if (ctx.editForm.id) {update(ctx.editForm).then(res => {ctx.$message.success('更新成功')ctx.editDialogVisible = falsectx.getList()})} else {add(ctx.editForm).then(res => {ctx.$message.success('添加成功')ctx.editDialogVisible = falsectx.getList()})}}})},edit(row) {if (row) {ctx.editForm = {id: row.id,code: row.code,name: row.name,url: row.url,}} else {ctx.editForm = {id: '',code: '',name: '',url: '',}}ctx.editDialogVisible = true},deleteById(id) {deleteById(id).then(res => {ctx.$message.success('删除成功')ctx.getList()})},getList() {ctx.loading = truelist().then(res => {ctx.list = res.datactx.loading = false})},})onMounted(() => {ctx.getList()})return {...toRefs(state),}},
}
</script><style></style>

这是典型的vue模板代码的结构,template、script和style三部分,template是html网页模板,javascript是逻辑代码,用于数据、事件绑定。

Vue3,首先导入方法:

import {getCurrentInstance,reactive,toRefs,ref,computed,watch,onMounted,
} from 'vue'

在setup方法中设置好template中可用的对象和方法,vue3中没有this,可以用ctx代替。

const { proxy: ctx } = getCurrentInstance()
  • 页面加载完成后调用onMounted,加载list,数据渲染在el-table组件中。
  • 点击添加或编辑按钮时调用edit方法,弹出编辑框el-dialog组件。
    el-dialog组件中数据表单使用el-form组件,提交时通过ctx.$refs.editForm.validate进行数据校验。
  • 删除方法,通过el-popconfirm加上确认行为。

代码地址及演示地址见博文:正则采集器——需求说明-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/51755.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springbootsecurity整合thymeleaf

首先创建一个springboot项目 然后加入相关依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation&q…

昇思 25 天学习打卡营第 15 天 | mindspore 实现 VisionTransformer 图像分类

1. 背景&#xff1a; 使用 mindspore 学习神经网络&#xff0c;打卡第 15 天&#xff1b;主要内容也依据 mindspore 的学习记录。 2. Vision Transformer 介绍&#xff1a; mindspore 实现 VisionTransformer 图像分类&#xff1b;VisionTransformer 论文地址 VisionTransfo…

深入分析MiniQMT实时订阅延迟测试代码

摘要 本文将深入分析两段MiniQMT平台的Python代码&#xff0c;这些代码用于测试实时数据订阅的延迟情况。我们将详细探讨代码的结构、关键功能以及它们在实时交易策略中的应用&#xff0c;并通过代码示例展示其工作原理。 背景介绍 MiniQMT是一个量化交易平台&#xff0c;支…

Redis是多线程还是单线程?

文章目录 1、用户态和内核态2、阻塞IO3、非阻塞IO4、IO多路复用4.1 select4.2 poll4.3 epoll4.4 epoll中的ET和LT4.5 epoll的服务端流程 5、信号驱动6、异步IO7、对比8、Redis是单线程的吗&#xff1f;9、单线程多线程网络模型变更 1、用户态和内核态 1、ubuntu和Centos 都是Li…

KADB heap表VS AO表插入数据测试

单条插入数据准备&#xff1a; test# \d test Table "public.test" Column | Type | Modifiers ------------------------------------------ a | integer | b | character varying(20) | Distributed by: (a) test# in…

day 02

作业&#xff1a; 1> 写一个日志文件&#xff0c;将程序启动后&#xff0c;每一秒的时间写入到文件中 1、2024- 7-29 10:31:19 2、2024- 7-29 10:31:20 3、2024- 7-29 10:31:21 ctrlc:停止程序 ./a.out 4、2024- 7-29 10:35:06 5、2024- 7-29 10:35:07 6、2024- 7-29 10:3…

轻松入门Linux—CentOS,直接拿捏 —/— <2>

一 、权限问题详细讲解 读写的权限可以分别写成 r, w, x 总共有九个权限&#xff0c;可以分组三大组分别是&#xff1a; user&#xff1a;当前文件所属用户的权限 group&#xff1a;与当前文件所属用户同一组的用户权限 others&#xff1a;其他用户的权限 故使用 u, g, o 来代表…

从装机到冯·诺依曼架构,揭秘计算机的硬件组成

在当今数字化的时代&#xff0c;计算机已经成为我们生活和工作中不可或缺的一部分。从日常办公到科学计算&#xff0c;从畅玩游戏到无人驾驶&#xff0c;计算机简直无所不能。而这一切的背后&#xff0c;离不开其精密而复杂的硬件组成。今天&#xff0c;我们将一起探索计算机的…

Java中的异常总结

异常的基本概念 异常&#xff08;Exception&#xff09;&#xff1a;表示程序在执行过程中出现的错误或异常情况。异常通常表示程序的非正常状态&#xff0c;需要处理以防止程序崩溃。错误&#xff08;Error&#xff09;&#xff1a;表示虚拟机出现的严重问题&#xff0c;通常…

Selenium Java中的isDisplayed()方法

isDisplayed&#xff08;&#xff09;方法用于确定元素是否可见。本文将详细讨论 的WebElement接口isDisplayed&#xff08;&#xff09;方法。 方法声明- boolean isDisplayed&#xff08;&#xff09;它能做什么&#xff1f;此方法用于判断元素是否显示。这个方法节省了我们…

ora-01438

ORA-01438是Oracle数据库中的一个常见错误&#xff0c;它表示在尝试插入或更新数据库表时&#xff0c;某个列的值超出了该列定义所允许的精度范围。这通常发生在处理数值类型数据时&#xff0c;如NUMBER类型&#xff0c;其中精度指的是数值的总位数&#xff08;包括整数部分和小…

带有扰动观测器的MPC电机控制

模型预测控制(Model Predictive Contro1, MPC)是一种先进的控制策略&#xff0c;虽然具有鲁棒性、建模简单、处理多变量系统、显示约束、预测未来行为和优化性能的能力等优势。它的不足在于预测控制行为的计算需要繁琐的计算量&#xff0c;以及抗干扰能力较弱。这里提出基于扰动…

HDFS原理

HDFS&#xff08;Hadoop Distributed File System&#xff09; HDFS——hadoop的分布式文件存储系统 HDFS原理19:49

day24——homework

1> 写一个日志文件&#xff0c;将程序启动后&#xff0c;每一秒的时间写入到文件中 1、2024- 7-29 10:31:19 2、2024- 7-29 10:31:20 3、2024- 7-29 10:31:21 ctrlc:停止程序 ./a.out 4、2024- 7-29 10:35:06 5、2024- 7-29 10:35:07 6、2024- 7-29 10:35:08 #include <…

视创云展:重塑线上会议体验,六大核心引领数字空间新纪元

视创云展以其革命性的“数字活动”解决方案为核心&#xff0c;精心构建了一个超越想象的未来数字世界。通过整合六大前沿技术模块&#xff0c;它不仅为参会者打造了一个身临其境的线上会议环境&#xff0c;更让每一位参与者都能跨越物理界限&#xff0c;深刻感受会议的每一个瞬…

前端八股速通(持续更新中...)

1、深拷贝和浅拷贝的区别 浅拷贝&#xff1a;浅拷贝是拷贝一层&#xff0c;引用类型共享地址。 如果属性是基本类型&#xff0c;拷贝的就是基本类型的值。 如果属性是引用类型&#xff0c;拷贝的就是内存地址。 意思是&#xff0c;当进行浅拷贝时&#xff0c;对于对象的每一…

PointCLIP: Point Cloud Understanding by CLIP

Abstract 近年来&#xff0c;基于对比视觉语言预训练(CLIP)的零镜头和少镜头学习在二维视觉识别中表现出了令人鼓舞的效果&#xff0c;该方法在开放词汇设置下学习图像与相应文本的匹配。然而&#xff0c;通过大规模二维图像-文本对预训练的CLIP是否可以推广到三维识别&#x…

关于#define的使用方法总结

文章目录 #define 预处理指令一、#define宏定义二、查看预处理文件三、#define 的使用方法四、C语言宏中“#”和“##”的用法五、常见的宏定义总结六、常考题目 #define 预处理指令 #define 是 C 和 C 编程语言中的预处理指令&#xff0c;用于定义宏&#xff08;macro&#xf…

斯坦福UE4 + C++课学习记录 13:UMG-血量条

文章目录 一、创建血量属性二、应用血量更改三、血量UI 一、创建血量属性 Unreal Motion Graphics (UMG)是 UE中用于创建用户界面 (UI) 的工具。它可以实现如下复杂功能&#xff1a; &#xff08;1&#xff09;动画&#xff1a;UMG 支持为控件添加动画。可以在 Widget Bluepri…

centos7已停用改用Rocky Linux9配置IPV4并安装docker

弃用Centos7&#xff0c;改用Rocky Linux9。 修改IP的方式有不同&#xff0c;不再是修改/etc/sysconfig/network-scripts/之下的脚本&#xff0c;系统也没有名叫network的服务。 系统通过NetworkManger和网络connetions来管理网卡和IP。 实际操作 Rocky Linux通过“系统连接”管…