- 提高你的JS技巧,让你的代码更简洁优!
前端技术栈
前端领域javascript开发语言ecmascript
给大家推荐一个实用面试题库1、前端面试题库(面试必备)推荐:★★★★★地址:web前端面试题库JavaScript中有许多简写技巧可以缩减代码长度、减少冗余并提高代码的可读性和可维护性。以下是20个有效提升效率的JavaScript简写技巧,帮助你编写更优雅的代码!移除数组假值可以使用filter()结合Boolean来简化移除数组假值操作。假值指的是在条件判断中被视为false的值,例如null
- 掌握20个JS技巧
javascript前端
1:找出数组中总和,最大值,最小值constarray=[5,4,7,8,9,2];console.log('总和',array.reduce((a,b)=>a+b));//35console.log('最大值',array.reduce((a,b)=>a>b?a:b));//9console.log('最小值',array.reduce((a,b)=>aa-b));//[1,5,10,25,40
- 前端开发中有哪些鲜为人知的技巧?
骨灰级收藏家
前端Web前端JavaScriptjavascript开发语言ecmascript
下面分享一些前端开发鲜为人知的HTML/CSS/JS技巧,希望大家可以有所收获。一、Datalist元素不知道为什么,这个元素不太被人所使用。标签被用于为元素提供一个“自动补全”的功能。例如:的id必须和input的list属性一致,这样才能使这两个元素绑定在一起。二、点击联动的标签和复选框如果你希望点击标签后复选框也发生相应操作,通常可以使用label元素的“for”属性,就比如下面代码:Iag
- JS技巧
追风筝的一朵云
#JS技巧**##三元运算符新手```javascriptlethungry=true;leteat;if(hungry==true){eat='yes';}else{eat='no';}```老手```javascriptlethungry=true;leteat=hungry==true?'yes':'no';```****##数字转字符串/字符串转数字新手```javascriptletnu
- 15条高效的JS技巧,你千万要收藏好了
前端Q群282549184
1、延迟函数delayconstdelay=ms=>newPromise((resolve,reject)=>setTimeout(resolve,ms))constgetData=status=>newPromise((resolve,reject)=>{status?resolve('done'):reject('fail')})constgetRes=async(data)=>{try{co
- web前端开发中遇到的问题整理记录——2020-07
有梦想的风筝
目录1.momentJS技巧2.if小技巧3..UncaughtTypeError:a[b].target.className.indexOfisnotafunction4.Maximumcallstacksizeexceededangular内容1.momentJS技巧两个日期/时间的时差moment(endTime).diff(moment(startTime),'years')moment(
- JS技巧
一笑奈何_3bea
//1.有条件地想对象添加属性constcondition=true;constperson={id:1,name:'XiaoHe',...(condition&&{age:16}),};//如果每个操作数的值都为true,则&&操作符返回最后一个求值表达式。因此返回一个对象{age:16},然后将其扩展为person对象的一部分。//2.空值合并??操作符只判断一个变量是否为null或undef
- js技巧
King小志
DOM与javascript转换query对象转换为DOMD对象,jquery提供两种方法将jquery对象转换为DOM对象,即[index]和get(index),var$txtName=$(“#txtName”);//jquery对象vartxtName=$txtName[0];//Dom对象alert(txtName.checked);//检测这个checkbox是否被选中通过get(ind
- JS技巧Canvas 性能优化脏矩形渲染实例详解
目录正文画布该如何更新?脏矩形渲染原理脏矩形渲染实现性能测试结尾正文使用Canvas做图形编辑器时,我们需要自己维护自己的图形树,来保存图形的信息,并定义元素之间的关系。我们改变画布中的某个图形,去更新画布,最简单的是清空画布,然后根据图形树将所有图形再绘制一遍,这在图形较少的情况下是没什么问题的。但如果图形数量很多,那绘制起来可能就出现卡顿了。那么,有没有什么办法来优化一下?有,脏矩形渲染。画布
- JS技巧动手实现红包兔子雨效果示例详解
目录前言展示效果技术栈思考与实现红包下落效果生成红包雨打开红包效果兔子雨效果拓展设置中奖概率后记前言人生天地之间,若白驹过隙,忽然而已。不知不觉中,2022年已然逝去,2023年也过去了半个月了。看到「兔了个兔」这个活动几天了,不过这周比较忙,没时间参与。心血来潮,捣鼓了一晚上,实现一个兔年的红包雨(兔子雨)效果~展示效果技术栈Vue2SCSS:实现红包雨(兔子雨)效果、按钮交互效果等。思考与实现
- JS技巧多状态页面中的mock方案详解
目录引言技术选型业务逻辑改造Eruda插件Mock数据整理引言我们有时候会遇到一个业务页面存在很多个状态,甚至子状态,比如订单详情就是其中的典型,涉及从订单创建到订单结束,以及售后等流程。维护起来每个状态对应一份数据,虽然我们QA提供了数据构造平台,但构造一份对应状态的数据还是需要花费不少时间,而且串行流程一旦出错的话只能重新来一遍。后期维护阶段也不容易构造对应状态的数据,导致排查页面问题比较耗时
- Threejs+Blender实现甜甜圈掉落效果| 大帅老猿threejs特训
前端three.js元宇宙
前言之前断断续续地跟着大帅浅学了一下threejs,投入精力不大却也学到了一些Threejs技巧和api。最近又和胖达学习了如何使用Blender进行3D建模、添加动画以及如何在Threejs中展示、控制3D模型,解答了我的疑惑,原来一些看似复杂的3D项目可以如此简单的实现。下面就带来甜甜圈案例,来了解threejs安装和基础应用分析需求要实现动图中的甜甜圈效果,按照代码层面的思路肯定是利用thr
- 【threejs】可视化大屏酷炫3D地图附源码
接着奏乐接着舞。
工作经验总结three.js3d
目录效果如下:1.前言:2.使用:1.修改整体的背景图可以使用颜色或用贴图改材质编辑方法:2.取消地图上柱状图显示3.更换地图、更换省份、市4.修改相机的视角,页面展示的远近角度5.修改地图的颜色及贴图6.关闭一些特效7.页面适配和在vue2版本中使用3.源码效果如下:1.前言:本文主要说明使用threejs技巧,来定制适合项目需求的样式,源码将在本文最后附上gitee地址。2.使用:1.修改整体
- JS技巧之一行赋值语句能玩出多少花样
目录前言第一种变化、写入到自执行函数中:第二种变化、用eval执行:第三种变化、变形的eval执行:第四种变化、利用构造函数:第五种变化、构造函数再升级:第六种变化、构造函数变形:第七种变化、混淆加密:总结前言今天,来做个测试,看看一行简单的JS赋值语句,有多少种写法。测试语句,仅三行:vara=1;a=2;console.log(a);针对第二行a=2赋值,看能变多少花样。第一种变化、写入到自执
- 掌握20个JS技巧
javascript前端
1:找出数组中总和,最大值,最小值constarray=[5,4,7,8,9,2];console.log('总和',array.reduce((a,b)=>a+b));//35console.log('最大值',array.reduce((a,b)=>a>b?a:b));//9console.log('最小值',array.reduce((a,b)=>aa-b));//[1,5,10,25,40
- 掌握这20个JS技巧,做一个不加班的前端人
华为云开发者社区
摘要:JavaScript真的是一门很棒的语言,值得学习和使用。对于给定的问题,可以有不止一种方法来达到相同的解决方案。在本文中,我们将只讨论最快的。本文分享自华为云社区《提高代码效率的20个JavaScript技巧和窍门》,作者:海拥。在我们的日常任务中,我们会编写诸如排序、搜索、查找唯一值、传递参数、交换值等功能,所以在这里我列出了我的速记技巧列表!JavaScript真的是一门很棒的语言,值
- 分享一些不常见却很实用的JS技巧
前言编程语言通常暗藏着各种技巧,熟练使用这些技巧可以提高开发效率。JavaScript就是一门技巧性很强的语言,掌握常见的语法技巧不但可以加深对语言特性的理解,还可以简化代码,提高编码效率。下面是列出一些JavaScript有用的技巧,相信总有一天会对你有所帮助。1、数组去重const numbers = [1,2, 3, 4, 4, 1]console.log([...new Set(numbe
- 如何让你的JavaScript函数更加优雅详解
目录对象参数使用解构命名回调函数让条件句具有描述性用Map或Object替换switch语句使用Object.assign设置默认属性删除重复代码,合并相似函数;删除弃用代码提炼函数总结准备写一个js技巧系列,主要就是总结js各种实用的小窍门、小妙招。本文主要是研究如何让我们的函数更清晰明了。对象参数使用解构如果希望函数接收很多参数(如果超过两个),那么就应该使用对象。在此基础上,可以使用解构语法
- 你应该了解的25个JS技巧
前端三少爷
写代码的时候总有一些东西是会重复出现的,次数多了你就会想找找捷径了。这类问题中有很大一部分解决起来甚至连库都不用装。下面就是我多年来收集的前25个捷径和小技巧。1.类型检查小工具JavaScript不是强类型语言,对此我推荐的最佳解决方案是TypeScript。但有时你只是想要一个简单的类型检查,这种时候JavaScript允许你使用“typeof”关键字。“typeof”的问题在于,将其用于某些
- 25个 js技巧
抽疯的稻草绳
1.类型检查小工具JavaScript不是强类型语言,对此我推荐的最佳解决方案是TypeScript。但有时你只是想要一个简单的类型检查,这种时候JavaScript允许你使用“typeof”关键字。“typeof”的问题在于,将其用于某些原语和函数时效果很好,但对于数组和对象来说,由于它们都被视为“对象”,因此很难把握它们之间的区别。constisOfType=(()=>{//createapl
- 大佬说:“不想加班你就背会这 10 条 JS 技巧”
前端飘哥
为了让自己写的代码更优雅且高效,特意向大佬请教了这10条JS技巧1.数组分割constlistChunk=(list=[],chunkSize=1)=>{constresult=[];consttmp=[...list];if(!Array.isArray(list)||!Number.isInteger(chunkSize)||chunkSize{if(!Array.isArray(firstL
- 你应该了解的25个JS技巧
JAVA_朴先生
javascript前端程序员技巧经验
写代码的时候总有一些东西是会重复出现的,次数多了你就会想找找捷径了。这类问题中有很大一部分解决起来甚至连库都不用装。下面就是我多年来收集的前25个捷径和小技巧。1.类型检查小工具JavaScript不是强类型语言,对此我推荐的最佳解决方案是TypeScript。但有时你只是想要一个简单的类型检查,这种时候JavaScript允许你使用“typeof”关键字。“typeof”的问题在于,将其用于某些
- 你应该了解的25个JS技巧
JAVA_朴先生
javascript前端程序员技巧经验
写代码的时候总有一些东西是会重复出现的,次数多了你就会想找找捷径了。这类问题中有很大一部分解决起来甚至连库都不用装。下面就是我多年来收集的前25个捷径和小技巧。1.类型检查小工具JavaScript不是强类型语言,对此我推荐的最佳解决方案是TypeScript。但有时你只是想要一个简单的类型检查,这种时候JavaScript允许你使用“typeof”关键字。“typeof”的问题在于,将其用于某些
- js技巧用Map集合代替Array遍历
伊泽瑞尔灬
很多时候我们在做页面的时候会遇到这样的一个情况,我们需要显示一个下拉框,然后需要把选择的值传到后台,而页面需要显示我们选择的数据项的名称,我们可能会这样实现:Title用Array实现:{{`当前选择:${showText},id为${selectId}`}}varvm=newVue({el:"#app",data:function(){return{selectId:'',showText:''
- JS技巧:在IE浏览器中正确显示PNG透明图片
webclass
WEB技术及应用ie浏览器javascriptfilterfloatfunction
PNG图片有很好的品质。阴影效果也不会有杂边,很流畅。如果插入网页的话可以给网站内容增色不少!更重要的是在不增加图片容量大小的情况下提高了页面的图片的质量。对于有复杂背景,如:在有颜色过度背景上插入不规则边框的图片带来极大很便利!但目前IE中对于插入的透明背景的.png的图片是不能正常显示的。IE会自动给".png"格式的图片加个灰色背景。解决这个的方法是增加javascript。具体方法如下:把
- 写出更好代码的5个js技巧
追求者2016
JavaScriptjavascript
写出更好代码的5个js技巧1.使用.map或者.forEach代替for遍历constnumbers=[1,2,3,4,5,6,7,8]//DON'Tfor(i=0;iconsole.log(number));//1,2,3,4,5,6,7,8//ORnumbers.forEach(number=>console.log(number));//1,2,3,4,5,6,7,8上面的代码循环数字并打印
- 26种你可能想不到的JS技巧
加油站站站
es7/8javascript
1.οncοntextmenu=“window.event.returnValue=false”将彻底屏蔽鼠标右键no2.取消选取、防止复制3.不准粘贴οnpaste="returnfalse"4.防止复制οncοpy="returnfalse;"oncut="returnfalse;"5.IE地址栏前换成自己的图标6.可以在收藏夹中显示出你的图标7.关闭输入法8.永远都会带着框架if(windo
- 【JS实用技巧】利用冒泡机制,减少事件绑定,优化页面性能
小神游
javascriptjquery事件监听事件绑定事件冒泡
引言无论新手老手,在前端开发中,经常要为DOM元素绑定事件,以实现某些功能。如何通过一些JS技巧,达到减少事件绑定,优化页面性能的目的呢?接下来介绍一下我个人对优化事件绑定的实践。我尽量写得通俗易懂一些,希望能为刚入门前端的人们带来帮助。也欢迎大家踊跃评论和指正,一起分享建议和想法哦。事件绑定利器:利用事件冒泡机制哈哈,放心,我不会强行地科普一堆浏览器事件机制晦涩的理论,事件传播机制在各种浏览器或
- JS技巧技法总结——闭包原理、数组展平、前端语音、Proxy 数据绑定和监听、计数器
孤篷
javascript前端es6语音
开发、阅读、学习中接触到、整理的一些知识点。JS计数器的几种实现全局变量letcount=0;constcountUp=()=>count++;闭包//javascriptconstcountUp=(()=>{letcount=0;return()=>{return++count;};})();console.log(countUp());//1console.log(countUp());//2
- JS技巧技法总结——闭包原理、数组展平、前端语音、Proxy 数据绑定和监听、计数器
孤篷
javascript前端es6语音
开发、阅读、学习中接触到、整理的一些知识点。JS计数器的几种实现全局变量letcount=0;constcountUp=()=>count++;闭包//javascriptconstcountUp=(()=>{letcount=0;return()=>{return++count;};})();console.log(countUp());//1console.log(countUp());//2
- PHP,安卓,UI,java,linux视频教程合集
cocos2d-x小菜
javaUIPHPandroidlinux
╔-----------------------------------╗┆
- 各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
bozch
.net.net mvc
在.net mvc5中,在执行某一操作的时候,出现了如下错误:
各表中的列名必须唯一。在表 'dbo.XXX' 中多次指定了列名 'XXX'。
经查询当前的操作与错误内容无关,经过对错误信息的排查发现,事故出现在数据库迁移上。
回想过去: 在迁移之前已经对数据库进行了添加字段操作,再次进行迁移插入XXX字段的时候,就会提示如上错误。
&
- Java 对象大小的计算
e200702084
java
Java对象的大小
如何计算一个对象的大小呢?
 
- Mybatis Spring
171815164
mybatis
ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
CustomerService userService = (CustomerService) ac.getBean("customerService");
Customer cust
- JVM 不稳定参数
g21121
jvm
-XX 参数被称为不稳定参数,之所以这么叫是因为此类参数的设置很容易引起JVM 性能上的差异,使JVM 存在极大的不稳定性。当然这是在非合理设置的前提下,如果此类参数设置合理讲大大提高JVM 的性能及稳定性。 可以说“不稳定参数”
- 用户自动登录网站
永夜-极光
用户
1.目标:实现用户登录后,再次登录就自动登录,无需用户名和密码
2.思路:将用户的信息保存为cookie
每次用户访问网站,通过filter拦截所有请求,在filter中读取所有的cookie,如果找到了保存登录信息的cookie,那么在cookie中读取登录信息,然后直接
- centos7 安装后失去win7的引导记录
程序员是怎么炼成的
操作系统
1.使用root身份(必须)打开 /boot/grub2/grub.cfg 2.找到 ### BEGIN /etc/grub.d/30_os-prober ### 在后面添加 menuentry "Windows 7 (loader) (on /dev/sda1)" { 
- Oracle 10g 官方中文安装帮助文档以及Oracle官方中文教程文档下载
aijuans
oracle
Oracle 10g 官方中文安装帮助文档下载:http://download.csdn.net/tag/Oracle%E4%B8%AD%E6%96%87API%EF%BC%8COracle%E4%B8%AD%E6%96%87%E6%96%87%E6%A1%A3%EF%BC%8Coracle%E5%AD%A6%E4%B9%A0%E6%96%87%E6%A1%A3 Oracle 10g 官方中文教程
- JavaEE开源快速开发平台G4Studio_V3.2发布了
無為子
AOPoraclemysqljavaeeG4Studio
我非常高兴地宣布,今天我们最新的JavaEE开源快速开发平台G4Studio_V3.2版本已经正式发布。大家可以通过如下地址下载。
访问G4Studio网站
http://www.g4it.org
G4Studio_V3.2版本变更日志
功能新增
(1).新增了系统右下角滑出提示窗口功能。
(2).新增了文件资源的Zip压缩和解压缩
- Oracle常用的单行函数应用技巧总结
百合不是茶
日期函数转换函数(核心)数字函数通用函数(核心)字符函数
单行函数; 字符函数,数字函数,日期函数,转换函数(核心),通用函数(核心)
一:字符函数:
.UPPER(字符串) 将字符串转为大写
.LOWER (字符串) 将字符串转为小写
.INITCAP(字符串) 将首字母大写
.LENGTH (字符串) 字符串的长度
.REPLACE(字符串,'A','_') 将字符串字符A转换成_
- Mockito异常测试实例
bijian1013
java单元测试mockito
Mockito异常测试实例:
package com.bijian.study;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.junit.Assert;
import org.junit.Test;
import org.mockito.
- GA与量子恒道统计
Bill_chen
JavaScript浏览器百度Google防火墙
前一阵子,统计**网址时,Google Analytics(GA) 和量子恒道统计(也称量子统计),数据有较大的偏差,仔细找相关资料研究了下,总结如下:
为何GA和量子网站统计(量子统计前身为雅虎统计)结果不同?
首先:没有一种网站统计工具能保证百分之百的准确出现该问题可能有以下几个原因:(1)不同的统计分析系统的算法机制不同;(2)统计代码放置的位置和前后
- 【Linux命令三】Top命令
bit1129
linux命令
Linux的Top命令类似于Windows的任务管理器,可以查看当前系统的运行情况,包括CPU、内存的使用情况等。如下是一个Top命令的执行结果:
top - 21:22:04 up 1 day, 23:49, 1 user, load average: 1.10, 1.66, 1.99
Tasks: 202 total, 4 running, 198 sl
- spring四种依赖注入方式
白糖_
spring
平常的java开发中,程序员在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理,spring提出了依赖注入的思想,即依赖类不由程序员实例化,而是通过spring容器帮我们new指定实例并且将实例注入到需要该对象的类中。依赖注入的另一种说法是“控制反转”,通俗的理解是:平常我们new一个实例,这个实例的控制权是我
- angular.injector
boyitech
AngularJSAngularJS API
angular.injector
描述: 创建一个injector对象, 调用injector对象的方法可以获得angular的service, 或者用来做依赖注入. 使用方法: angular.injector(modules, [strictDi]) 参数详解: Param Type Details mod
- java-同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待
bylijinnan
Integer
public class PC {
/**
* 题目:生产者-消费者。
* 同步访问一个数组Integer[10],生产者不断地往数组放入整数1000,数组满时等待;消费者不断地将数组里面的数置零,数组空时等待。
*/
private static final Integer[] val=new Integer[10];
private static
- 使用Struts2.2.1配置
Chen.H
apachespringWebxmlstruts
Struts2.2.1 需要如下 jar包: commons-fileupload-1.2.1.jar commons-io-1.3.2.jar commons-logging-1.0.4.jar freemarker-2.3.16.jar javassist-3.7.ga.jar ognl-3.0.jar spring.jar
struts2-core-2.2.1.jar struts2-sp
- [职业与教育]青春之歌
comsci
教育
每个人都有自己的青春之歌............但是我要说的却不是青春...
大家如果在自己的职业生涯没有给自己以后创业留一点点机会,仅仅凭学历和人脉关系,是难以在竞争激烈的市场中生存下去的....
&nbs
- oracle连接(join)中使用using关键字
daizj
JOINoraclesqlusing
在oracle连接(join)中使用using关键字
34. View the Exhibit and examine the structure of the ORDERS and ORDER_ITEMS tables.
Evaluate the following SQL statement:
SELECT oi.order_id, product_id, order_date
FRO
- NIO示例
daysinsun
nio
NIO服务端代码:
public class NIOServer {
private Selector selector;
public void startServer(int port) throws IOException {
ServerSocketChannel serverChannel = ServerSocketChannel.open(
- C语言学习homework1
dcj3sjt126com
chomework
0、 课堂练习做完
1、使用sizeof计算出你所知道的所有的类型占用的空间。
int x;
sizeof(x);
sizeof(int);
# include <stdio.h>
int main(void)
{
int x1;
char x2;
double x3;
float x4;
printf(&quo
- select in order by , mysql排序
dcj3sjt126com
mysql
If i select like this:
SELECT id FROM users WHERE id IN(3,4,8,1);
This by default will select users in this order
1,3,4,8,
I would like to select them in the same order that i put IN() values so:
- 页面校验-新建项目
fanxiaolong
页面校验
$(document).ready(
function() {
var flag = true;
$('#changeform').submit(function() {
var projectScValNull = true;
var s ="";
var parent_id = $("#parent_id").v
- Ehcache(02)——ehcache.xml简介
234390216
ehcacheehcache.xml简介
ehcache.xml简介
ehcache.xml文件是用来定义Ehcache的配置信息的,更准确的来说它是定义CacheManager的配置信息的。根据之前我们在《Ehcache简介》一文中对CacheManager的介绍我们知道一切Ehcache的应用都是从CacheManager开始的。在不指定配置信
- junit 4.11中三个新功能
jackyrong
java
junit 4.11中两个新增的功能,首先是注解中可以参数化,比如
import static org.junit.Assert.assertEquals;
import java.util.Arrays;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runn
- 国外程序员爱用苹果Mac电脑的10大理由
php教程分享
windowsPHPunixMicrosoftperl
Mac 在国外很受欢迎,尤其是在 设计/web开发/IT 人员圈子里。普通用户喜欢 Mac 可以理解,毕竟 Mac 设计美观,简单好用,没有病毒。那么为什么专业人士也对 Mac 情有独钟呢?从个人使用经验来看我想有下面几个原因:
1、Mac OS X 是基于 Unix 的
这一点太重要了,尤其是对开发人员,至少对于我来说很重要,这意味着Unix 下一堆好用的工具都可以随手捡到。如果你是个 wi
- 位运算、异或的实际应用
wenjinglian
位运算
一. 位操作基础,用一张表描述位操作符的应用规则并详细解释。
二. 常用位操作小技巧,有判断奇偶、交换两数、变换符号、求绝对值。
三. 位操作与空间压缩,针对筛素数进行空间压缩。
&n
- weblogic部署项目出现的一些问题(持续补充中……)
Everyday都不同
weblogic部署失败
好吧,weblogic的问题确实……
问题一:
org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component class: URL [zip:E:/weblogic/user_projects/domains/base_domain/serve
- tomcat7性能调优(01)
toknowme
tomcat7
Tomcat优化: 1、最大连接数最大线程等设置
<Connector port="8082" protocol="HTTP/1.1"
useBodyEncodingForURI="t
- PO VO DAO DTO BO TO概念与区别
xp9802
javaDAO设计模式bean领域模型
O/R Mapping 是 Object Relational Mapping(对象关系映射)的缩写。通俗点讲,就是将对象与关系数据库绑定,用对象来表示关系数据。在O/R Mapping的世界里,有两个基本的也是重要的东东需要了解,即VO,PO。
它们的关系应该是相互独立的,一个VO可以只是PO的部分,也可以是多个PO构成,同样也可以等同于一个PO(指的是他们的属性)。这样,PO独立出来,数据持