20240612前端问题总结

2024-06-13 04:20

本文主要是介绍20240612前端问题总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

20240612前端问题总结

给定固定大小的父 子盒子,要实现子盒子上下左右居中

使用calc()计算,子绝父相和子元素调整位置,flex弹性盒布局,transform,table-cell,浮动六种方法展示子元素垂直水平居中。

<div class="big"><div class="small"></div>
</div>

calc()计算

 .big {background-color: blue;width: 600px;height: 600px;overflow: hidden;}.small {background-color: burlywood;height: 200px;width: 200px;margin: calc((600px - 200px) / 2);}

在这里插入图片描述

如果父元素和子元素宽高不等,下面代码同样没有问题

    .big {background-color: blue;width: 600px;height: 500px;overflow: hidden;}.small {background-color: burlywood;height: 300px;width: 200px;margin: calc((500px - 300px) / 2) calc((600px - 200px) / 2);}

注意margin后面两个值的时候,第一个值代表上下外边距的值,第二个值代表左右外边距的值,所以calc先计算上下高度再计算宽度。
在这里插入图片描述

子绝父相+子元素调整位置

父元素相对定位,子元素绝对定位,调整子元素使其垂直水平居中

    .big {width: 600px;height: 500px;background-color: blue;position: relative;}.small {height: 300px;width: 200px;background-color: burlywood;position: absolute;top: 0px;bottom: 0px;left: 0px;right: 0px;margin: auto;}

flex弹性盒布局

display:flex弹性盒布局设置元素水平垂直居中对齐

    .big {width: 600px;height: 500px;background-color: blue;display: flex;justify-content: center;align-items: center;}.small {height: 300px;width: 200px;background-color: burlywood;}

子绝父相+transform

    .big {width: 600px;height: 500px;background-color: blue;position: relative;}.small {height: 300px;width: 200px;background-color: burlywood;position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);}

单元格table-cell布局

    .big {width: 600px;height: 500px;background-color: blue;display: table-cell;vertical-align: middle;}.small {height: 300px;width: 200px;background-color: burlywood;vertical-align: middle;margin: 0 auto;}

浮动

给子元素设置左浮动使其脱离文档流,然后计算父元素和子元素的宽高差除以2设置上外边距和左外边距

<style>.big {width: 600px;height: 500px;background-color: blue;}.small {height: 300px;width: 200px;background-color: burlywood;float: left;margin-top: 100px;margin-left: 200px;}
</style>

给定一个对象数组,找到id为1的所有元素,返回一个新的数组

这个问题尝试用数组的常用方法解决,filter,splice,slice,concat,find,includes。
以下面的数组对象为例

var students = [{ id: 1, name: "张三", age: 18, gender: "男" },{ id: 1, name: "李四", age: 19, gender: "女" },{ id: 1, name: "王五", age: 20, gender: "男" },{ id: 2, name: "阿狗", age: 18, gender: "男" },{ id: 3, name: "阿猫", age: 19, gender: "女" },{ id: 4, name: "刘柳", age: 20, gender: "男" }
];

使用filter过滤元素返回一个新数组

var result = students.filter(function (student) {return student.id == 1
})
console.log(result)

箭头函数

const result = students.filter(students => students.id === 1)
console.log(result)

reduce函数解决

var result = students.reduce((acc, student) => {if (student.id === 1) {acc.push(student);}return acc;
}, []);console.log(result);

后端一次性给定全部数据量,前端实现分页,描述实现逻辑。

基于vue2和element-ui实现,代码提取自简历中的信贷后台管理项目信贷申请核心代码。
封装请求后端数据的接口并调用

//  在IndexView中调用loan.js
// 定义获取申请列表的接口
export const getLoanList = (params) => {return request({url: '/loan/list',method: 'get',params})
}
  //页面加载就请求表格数据(异步获取数据)mounted() {this.getLoanList();}

在vue2的data中定义数据

 data() {return {rows: 0,value:false,//数据只有一页隐藏分页updateForm: {id: 0,name: "",sex: "",mobile_phone:"",},pageOptions: {pageNo: 1,//当前页面pageSize: 10,//页面显示数据条数},query: "",//名称//表格数据tableData: [],columns: [{label: "姓名",prop: "name",width: "80",},{label: "出生日期",prop: "birthday",width: "160",},{label: "性别",prop: "sex",},{label: "教育程度",prop: "education",},{label: "居住地址",prop: "address1",},{label: "手机号",prop: "mobile_phone",},{label: "申请状态",prop: "status",},{label: "操作",width: "280",prop: "opts",},],}},

获取当前页需要显示的数据,使用elemen-ui的table组件在模板中渲染接收到的后端的数据

  <!--tableData是表格数据-->   <el-table :data="tableData"  ><el-table-column type="index" label="序号"></el-table-column><el-table-column v-for="(item,index) in columns":key="index":label="item.label":prop="item.prop":width="item.width"align="center"></el-table-column>  </el-table>

使用element-ui的分页组件,之后关于分页遇见调用的方法在methods里面写

  <!-- 分页功能 --><!-- size-change处理页码大小;current-change事件处理当前页变动时候触发的事件。 --><el-pagination@size-change="handleSizeChange"@current-change="handleCurrentChange":hide-on-single-page="value":page-sizes="[10, 20, 30, 40]":page-size="pageOptions.pageSize"layout="total, sizes, prev, pager, next, jumper":total="rows"></el-pagination>

在method里面写关于分页的方法

handleSizeChange(val) {this.pageOptions.pageSize = val;this.getLoanList();console.log(`每页 ${val} 条`);},handleCurrentChange(val) {this.pageOptions.pageNo = val;this.getLoanList();console.log(`当前页: ${val}`);},

绑定当前页面页数和当前页面显示数据条数,调用后端数据请求接口请求数据返回

vue2实现

在Vue组件中定义数据:

data() {return {allData: [], // 后端一次性给定的全部数据量pageSize: 10, // 每页显示的数据条数currentPage: 1 // 当前页数};
}

创建计算属性来获取当前页需要显示的数据:

computed: {paginatedData() {const startIndex = (this.currentPage - 1) * this.pageSize;const endIndex = startIndex + this.pageSize;return this.allData.slice(startIndex, endIndex);}
}

在模板中渲染分页数据:

<div v-for="data in paginatedData" :key="data.id"><!-- 显示每页数据的内容 -->
</div>

添加分页功能,包括上一页和下一页的按钮:

<button @click="goToPage(currentPage - 1)" :disabled="currentPage === 1">上一页</button>
<button @click="goToPage(currentPage + 1)" :disabled="currentPage * pageSize >= allData.length">下一页</button>

实现跳转到指定页数的方法:

methods: {goToPage(page) {this.currentPage = page;}
}

如何实现一个父页面的弹窗功能,描述显隐和传参的实现逻辑

我的简历项目中的实现

简历中的信贷后台管理中有弹窗功能,在当前页面(父页面)中使用弹窗组件。弹窗使用了element的dailog组件。visible和close设置弹窗的显示隐藏

 <el-dialog title="编辑页面弹窗" :visible="dialogVisible"  @close="dialogVisible = false"  ><div class="form-box">编辑表格</div></el-dialog>

通过data返回数据传参

 data() {return {dialogVisible: false,   //是否显示对话框rows: 0,value:false,//数据只有一页隐藏分页}}

method写关于编辑的操作

    //编辑操作async editApplication(row) {this.dialogVisible = true;this.$nextTick(() => {this.updateForm.id = row.id;this.updateForm.name = row.name;this.updateForm.sex = row.sex;this.updateForm.mobile_phone = row.mobile_phone;});},

简单vue2实现

上面是基于element框架实现的,若不使用element,实现一个父页面的弹窗功能可以使用Vue2中的slot(插槽)和props(属性)来实现

<template><div><button @click="showModal = true">打开弹窗</button><modal :is-show="showModal" :message="modalMessage" @close="showModal = false"><!-- 弹窗内容 --></modal></div>
</template><script>
import Modal from './Modal.vue';export default {components: {Modal},data() {return {showModal: false,modalMessage: '这是父页面传递给弹窗组件的参数'}}
}
</script>

在父组件的模板中,通过modal标签引入弹窗组件,并传递了is-show和message两个props,用来控制弹窗的显隐状态和传递参数。同时,通过插入标签,可以在父组件中自定义弹窗的内容。

在弹窗组件中接收和使用父组件传递的props:

<template><div class="modal-mask" :class="{ 'is-show': isShow }"><div class="modal-close" @click="$emit('close')">×关闭</div><div class="modal-body"><p>{{ message }}</p><slot></slot></div></div>
</template><script>
export default {props: {isShow: {type: Boolean,default: false},message: {type: String,default: ''}}
}
</script>

在弹窗组件中,通过props接收父组件传递的is-show和message,并使用v-bind绑定到相应的HTML元素上进行显示。同时,在关闭弹窗时通过 $emit 触发一个close事件,用来向父组件传递弹窗关闭的通知。

这篇关于20240612前端问题总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1056265

相关文章

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable