- js中对象常用方法
吃肉肉不吃肉肉
Object.assign()…用于克隆varfirst={name:'kong'};varlast={age:18};varperson=Object.assign(first,last);console.log(person);//{name:'kong',age:18Object.is()…用于判断两个值是否相同Object.is(a,b);//返回true或false//注意,该函数与==
- js中批量修改对象属性
首先,有这个对象leta={id:1,name:'张三',age:18,sex:0}需求:同时修改name,id,并添加一个新属性c常规写法:a.id=2;a.name='李四';a.c=1;但这种写法遇到批量就会很麻烦解决方法:方法1:使用Object.assign()Object.assign()常用来拷贝合并对象,相同属性替换,不同属性新增写法:a=Object.assign(a,{id:2
- uniapp 拦截器
满楼、
前端uni-appvue.js
exportdefault{config:{baseURL:'https://xxx.xxx.com',header:{},dataType:'json',//#ifndefMP-ALIPAY||APP-PLUSresponseType:'text',//#endif//注:如果局部custom与全局custom有同名属性,则后面的属性会覆盖前面的属性,相当于Object.assign(全局,局部
- 浅说深拷贝(Deep Copy)与浅拷贝(Shallow Copy)
=^_^=喵喵
javascript前端开发语言
在JavaScript中,深拷贝和浅拷贝是两种不同的数据复制方式,主要区别在于如何处理引用类型数据(如对象、数组)。1.浅拷贝(ShallowCopy)定义:只复制对象的第一层属性,如果属性是引用类型(如对象、数组),则复制的是引用,而不是实际数据。特点:原始对象和拷贝后的对象共享引用类型的属性。修改其中一个对象的引用类型属性会影响另一个对象。实现方式:Object.assign()(仅第一层深拷
- 深拷贝和浅拷贝
独步炎凉的大彬
前端面试题javascript前端vue.js
浅拷贝是一种仅复制对象最外层属性的拷贝方式,对于基本类型直接复制值,对于引用类型则复制内存地址,导致新旧对象共享同一引用数据。实例:实现方法:使用赋值运算符(=)或者Object.assign()函数进行拷贝//浅拷贝consta=[1,2,3,4]constb=ab[0]=5console.log(a)//[5,2,3,4]console.log(b)//[5,2,3,4]深拷贝递归复制所有嵌
- JS在数组对象中添加新字段
烂笔头儿@
javascript
第一步使用forEach遍历数组然后通过Object.assign()来添加vararr=[{age:18;name:‘as’},{age:18;name:‘as’},]//添加新字段arr.forEach(item=>{Object.assign(item,{sex:‘男’})})
- 手写一个深拷贝函数
宋哈哈
手写系列
Object.assign和展开运算符都是浅拷贝如何实现一个深拷贝呢要考虑传入变量为null和undefined的情况要处理日期Date和正则RegExp的情况不是引用类型的直接返回functiondeepClone(obj){if(obj==null)returnobj;//如果是null或者undefined直接返回//正则表达式或者日期对象直接返回if(objinstanceofDate)r
- HarmonyOS开发,遇到 Object.assign(this, source)报错怎么解决?
MardaWang
HarmonyOSNEXTOpenHarmonyharmonyostypescript
最近在升级某个api9的鸿蒙项目到api12,发现项目中较多用到如下图所示这样的代码,然后升级到api12就会编译报错:Usageofstandardlibraryisrestricted(arkts-limited-stdlib)。报错原因ArkTS是基于TypeScript进行扩展的,虽然大部分TypeScript语法和标准库可以使用,但由于HarmonyOS平台的特殊性,部分标准库的功能可能
- (04)JavaScript 中 Object的属性详解
xluo1715
javascriptjavascript开发语言ecmascript前端学习
以下是JavaScript中Object类型的主要方法、属性和示例。内容分为静态方法(通过Object构造函数调用)和实例方法/属性(通过对象实例调用):一、静态方法(Object.xxx)Object.assign(target,...sources)合并源对象的可枚举属性到目标对象。constobj1={a:1};constobj2={b:2};constmerged=Object.assig
- JS--Object对象方法
zyt0502
javascriptjavascript前端开发语言
1.assign():将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。属于浅复制只能复制一层只能将对象属性赋值给目标对象,varo={a:1,b:2};varo1=Object.create(o);o1.c=3;o1.d=4;console.log(o1);varo2={e:4,f:5};Object.assign(o2,o1);console.log(o2);2.crea
- js对象常用方法和es6对象新增方法
含含要暴怒
对象解构:基本;有剩余值运算符...rest;有默认值;解析对象不分顺序(变量名要和键名一致);解构对象.png【对象】1.对象的简写(变量名和对象的键一致的时候才可以);2.对象属性表达式[];3.对象的拷贝合并Object.assign();4.对象扩展...{...a,...b}复制与合并对象;【对象数据类型的弱点】1.对象的键名只能是字符串或者symbol;2.对象没有顺序;3.对象的长度
- vue2开发心得
Albert.H.Holmes
vue.js前端javascript
1.computedcomputed是一个对象,它包含了一系列计算属性。计算属性是基于它们的依赖进行缓存的计算值。只有当依赖发生变化时,计算属性才会重新计算。这使得计算属性非常适合执行昂贵的计算或派生状态。computed中的属性是响应式的,这意味着当它们的依赖项发生变化时,Vue将自动更新依赖于这些计算属性的任何DOM。2.Object.assign()函数Object.assign()函数用于
- vue想对象里面添加键值对的方法
lucky*girl
vue前端
1、Vue.set(target,propertyName/index,value)Vue.set(要填加的数组名称,键,值)2、Object.assign('对象',{key:'value'}
- resetFields()失效
虾仁不眨眼ok
前端javascripthtmlvue
问题描述先点击新增,再取消弹窗。resetFields()正常运行,清空表单内容。先点击编辑,再新增,表单内容不能清空。解决方法在nextTick里赋值表单内容,因为弹窗会把第一次赋值的内容当成初始值,所以要在弹窗加载完之后再赋值constopenModal=(data)=>{base.visible=true;nextTick(()=>{base.formData=Object.assign({
- 【JavaScript】深浅拷贝
STATICHIT静砸
JavaScriptjavascript前端开发语言
JavaScript中复制对象有深拷贝和浅拷贝两种方式浅拷贝:浅拷贝只复制对象的第一层属性,而不复制嵌套对象的引用。这意味着如果原始对象包含嵌套对象,浅拷贝后的对象仍然会共享这些嵌套对象的引用。可以使用`Object.assign()`或展开运算符(`...`)来进行浅拷贝。//浅拷贝示例//1.使用Object.assignconstoriginalObj={a:1,b:{c:2}};const
- object.assign
peerben
Object.assign(target,...sources)如果目标对象中的属性具有相同的键,则属性将被源中的属性覆盖。后来的源的属性将类似地覆盖早先的属性。Object.assign方法只会拷贝源对象自身的并且可枚举的属性到目标对象。该方法使用源对象的[[Get]]和目标对象的[[Set]],所以它会调用相关getter和setter。因此,它分配属性,而不仅仅是复制或定义新的属性。如果合并
- Vue3快速上手(七) ref和reactive对比
一掬净土
Vuevue3refreactive响应式对象对比
一、ref和reactive对比表格形式更加直观吧:项目refreactive是否支持基本类型支持不支持是否支持对象类型支持支持对象类型是否支持属性直接赋值不支持,需要.value支持是否支持直接重新分配对象支持,因为操作的.value不支持,需要使用object.assign()方法是否支持基本类型支持不支持响应式对象类型ref和reactive都是支持的。一般用哪种都是可以的。但是对于属性较多
- 16.扩展运算符的作用及使用场景
叫我阿东就行
前端面试JS篇前端javascript开发语言
(1)对象扩展运算符对象的扩展运算符(...)用于取出参数对象中的所有可遍历属性,拷贝到当前对象之中。letbar={a:1,b:2};letbaz={...bar};//{a:1,b:2}上述方法实际上等价于:letbar={a:1,b:2};letbaz=Object.assign({},bar);//{a:1,b:2}Object.assign方法用于对象的合并,将源对象(source)的所
- 记录下开发遇到的小错误
小小小小的人头
1.TypeError:Cannotvonverundefinedornulltoobject1、Object.keys()中传错了参数2、由于undefined和null无法转成对象,所以如果它们做为Object.assign()的参数(只有一个参数),也会报错
- JS对象 Object.assign()
长沙xtt
JS进阶javascript开发语言ecmascript
对象字面量JS中的对象:JavaScript对象是变量的内容放置变量或函数对象字面量是一种简单的键值对数据结构letobj={Pcode:{a:'1'},pName:'Apple',getData(){console.log(obj.Pcode,obj.pName);}};//添加属性//obj.Pcode=10001;//obj.pName='Apple';//obj.getData=funct
- Object.assign() 方法的使用详解
Army-海军
JavaScriptES6Object.assignobjectjs
Object.assign()方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。注意:会改变源对象语法:Object.assign(target,...sources)target目标对象。sources源对象。1.目标对象中的属性具有相同的键,则属性将被源对象中的属性覆盖。后面的源对象的属性将类似地覆盖前面的源对象的属性。2.Object.assign方法只会拷贝源
- Object.assign()
谬蓝
vue.js前端javascript
Object.assign()对象的拷贝Object.assign()方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。Object.assign(target,...sources)【target:目标对象】,【souce:源对象(可多个)】例子:constobject1={a:1,b:2,c:3};constobject2=Object.assign({c:4,d
- 【ES6】Object.assign方法与深浅拷贝
卡卡桃乐西
ES6javascript开发语言ecmascript
文章目录一、Object.assign二、用法详解1.Object.assign浅拷贝2.实现深拷贝3.自定义函数实现深拷贝总结一、Object.assignObject.assign方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target)。Object.assign方法的第一个参数是目标对象,后面的参数都是源对象。注意,如果目标对象与源对象有同名属性,或多个源
- Object.assign()及深拷贝
jokren
语法:Object.assign(target,…sources)target:目标对象,sources:源对象用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。consttarget={a:1,b:2};constsource={b:4,c:5};constreturnedTarget=Object.assign(target,source);console.log(t
- 总结Object.assign()用法
贝塔贝卡贝
object
Object.assign(target,…source):用于将所有可枚举属性(enumerable:true)的值从一个或多个源对象(source)复制到目标对象(taget),并将返回目标对象。一、Object.assign()对象的拷贝注意:1.如果目标对象中的属性具有相同的键,则属性将被源对象中的属性覆盖。后面的源对象的属性将类似地覆盖前面的源对象的属性2.Object.assign()
- Object.assign用法
Smile_zxx
javascript前端typescriptvuevue.js
1、是什么Object.assign()方法用于将所有可枚举属性的值从一个或多个源对象分配到目标对象。它将返回目标对象。consta={name:'张三'}constb={age:'18',sex:'女'}constc=Object.assign(a,b)console.log(c)//{name:'张三',age:'18',sex:'女'}console.log(a)//{name:'张三',a
- 详细分析Object.assign()的用法(附Demo)
码农研究僧
前端js前端
目录前言1.基本知识2.基本操作3.深入理解3.1浅拷贝3.2深拷贝前言需要将一个或多个对象的属性合并到目标对象中时,Object.assign()是一个非常有用的工具以下是对Object.assign()的详细分析、概念解释和演示示例1.基本知识Object.assign()是JavaScript中一个用于复制一个或多个源对象自身可枚举的属性到目标对象的方法它的语法如下:Object.assig
- javascript之Object.assign实现浅拷贝的原理以及实现
松宝写代码
es6JavaScriptObject.assign()浅拷贝的原理模拟实现浅拷贝
一、前言之前在前面一篇学习了赋值,浅拷贝和深拷贝。介绍了这三者的相关知识和区别。传送门:https://www.mwcxs.top/page/592.html本文会介绍浅拷贝Object.assign()的实现原理,然后咱们试着实现一个浅拷贝。二、浅拷贝Object.assign()什么是浅拷贝?浅拷贝就是创建一个新对象,这个对象有着原始对象属性值的一份精确拷贝。浅拷贝Object.assign(
- js对象利用object.assign实现递归深拷贝
qq_48378883
js常用库javascript前端开发语言
constdeepClone=(data)=>{varcloneobj=Object.assign({},data)//拷贝单层对象for(varkeyindata){//循环if(typeofcloneobj[key]==='object'){//判断对象cloneobj[key]=deepClone(cloneobj[key])//递归拷贝}}returncloneobj//返回深拷贝后的对象
- 关于js的引用传递问题(对象=对象)
空气啥都想学
首先是代码段以及显示问题代码块我在想做一个数据回显功能时发现就算用个局部变量接收传来的row对象,改变临时对象值时也会改变原row对象中的值,所以我想起了之前学的java中没有引用传递只有值传递,js中可能会有值传递这鬼东西,试了试输出果然不对劲输出原显示因为引用传递被改了然后我查到了这个方法Object.assign({},data);用上,试了多少次都没变输出页面显示
- 数据采集高并发的架构应用
3golden
.net
问题的出发点:
最近公司为了发展需要,要扩大对用户的信息采集,每个用户的采集量估计约2W。如果用户量增加的话,将会大量照成采集量成3W倍的增长,但是又要满足日常业务需要,特别是指令要及时得到响应的频率次数远大于预期。
&n
- 不停止 MySQL 服务增加从库的两种方式
brotherlamp
linuxlinux视频linux资料linux教程linux自学
现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库。前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作。
一般在线增加从库有两种方式,一种是通过mysqldump备份主库,恢复到从库,mysqldump是逻辑备份,数据量大时,备份速度会很慢,锁表的时间也会很长。另一种是通过xtrabacku
- Quartz——SimpleTrigger触发器
eksliang
SimpleTriggerTriggerUtilsquartz
转载请出自出处:http://eksliang.iteye.com/blog/2208166 一.概述
SimpleTrigger触发器,当且仅需触发一次或者以固定时间间隔周期触发执行;
二.SimpleTrigger的构造函数
SimpleTrigger(String name, String group):通过该构造函数指定Trigger所属组和名称;
Simpl
- Informatica应用(1)
18289753290
sqlworkflowlookup组件Informatica
1.如果要在workflow中调用shell脚本有一个command组件,在里面设置shell的路径;调度wf可以右键出现schedule,现在用的是HP的tidal调度wf的执行。
2.designer里面的router类似于SSIS中的broadcast(多播组件);Reset_Workflow_Var:参数重置 (比如说我这个参数初始是1在workflow跑得过程中变成了3我要在结束时还要
- python 获取图片验证码中文字
酷的飞上天空
python
根据现成的开源项目 http://code.google.com/p/pytesser/改写
在window上用easy_install安装不上 看了下源码发现代码很少 于是就想自己改写一下
添加支持网络图片的直接解析
#coding:utf-8
#import sys
#reload(sys)
#sys.s
- AJAX
永夜-极光
Ajax
1.AJAX功能:动态更新页面,减少流量消耗,减轻服务器负担
2.代码结构:
<html>
<head>
<script type="text/javascript">
function loadXMLDoc()
{
.... AJAX script goes here ...
- 创业OR读研
随便小屋
创业
现在研一,有种想创业的想法,不知道该不该去实施。因为对于的我情况这两者是矛盾的,可能就是鱼与熊掌不能兼得。
研一的生活刚刚过去两个月,我们学校主要的是
- 需求做得好与坏直接关系着程序员生活质量
aijuans
IT 生活
这个故事还得从去年换工作的事情说起,由于自己不太喜欢第一家公司的环境我选择了换一份工作。去年九月份我入职现在的这家公司,专门从事金融业内软件的开发。十一月份我们整个项目组前往北京做现场开发,从此苦逼的日子开始了。
系统背景:五月份就有同事前往甲方了解需求一直到6月份,后续几个月也完
- 如何定义和区分高级软件开发工程师
aoyouzi
在软件开发领域,高级开发工程师通常是指那些编写代码超过 3 年的人。这些人可能会被放到领导的位置,但经常会产生非常糟糕的结果。Matt Briggs 是一名高级开发工程师兼 Scrum 管理员。他认为,单纯使用年限来划分开发人员存在问题,两个同样具有 10 年开发经验的开发人员可能大不相同。近日,他发表了一篇博文,根据开发者所能发挥的作用划分软件开发工程师的成长阶段。
初
- Servlet的请求与响应
百合不是茶
servletget提交java处理post提交
Servlet是tomcat中的一个重要组成,也是负责客户端和服务端的中介
1,Http的请求方式(get ,post);
客户端的请求一般都会都是Servlet来接受的,在接收之前怎么来确定是那种方式提交的,以及如何反馈,Servlet中有相应的方法, http的get方式 servlet就是都doGet(
- web.xml配置详解之listener
bijian1013
javaweb.xmllistener
一.定义
<listener>
<listen-class>com.myapp.MyListener</listen-class>
</listener>
二.作用 该元素用来注册一个监听器类。可以收到事件什么时候发生以及用什么作为响
- Web页面性能优化(yahoo技术)
Bill_chen
JavaScriptAjaxWebcssYahoo
1.尽可能的减少HTTP请求数 content
2.使用CDN server
3.添加Expires头(或者 Cache-control) server
4.Gzip 组件 server
5.把CSS样式放在页面的上方。 css
6.将脚本放在底部(包括内联的) javascript
7.避免在CSS中使用Expressions css
8.将javascript和css独立成外部文
- 【MongoDB学习笔记八】MongoDB游标、分页查询、查询结果排序
bit1129
mongodb
游标
游标,简单的说就是一个查询结果的指针。游标作为数据库的一个对象,使用它是包括
声明
打开
循环抓去一定数目的文档直到结果集中的所有文档已经抓取完
关闭游标
游标的基本用法,类似于JDBC的ResultSet(hasNext判断是否抓去完,next移动游标到下一条文档),在获取一个文档集时,可以提供一个类似JDBC的FetchSize
- ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 的解决方法
白糖_
ORA-12514
今天通过Oracle SQL*Plus连接远端服务器的时候提示“监听程序当前无法识别连接描述符中请求服务”,遂在网上找到了解决方案:
①打开Oracle服务器安装目录\NETWORK\ADMIN\listener.ora文件,你会看到如下信息:
# listener.ora Network Configuration File: D:\database\Oracle\net
- Eclipse 问题 A resource exists with a different case
bozch
eclipse
在使用Eclipse进行开发的时候,出现了如下的问题:
Description Resource Path Location TypeThe project was not built due to "A resource exists with a different case: '/SeenTaoImp_zhV2/bin/seentao'.&
- 编程之美-小飞的电梯调度算法
bylijinnan
编程之美
public class AptElevator {
/**
* 编程之美 小飞 电梯调度算法
* 在繁忙的时间,每次电梯从一层往上走时,我们只允许电梯停在其中的某一层。
* 所有乘客都从一楼上电梯,到达某层楼后,电梯听下来,所有乘客再从这里爬楼梯到自己的目的层。
* 在一楼时,每个乘客选择自己的目的层,电梯则自动计算出应停的楼层。
* 问:电梯停在哪
- SQL注入相关概念
chenbowen00
sqlWeb安全
SQL Injection:就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。
具体来说,它是利用现有应用程序,将(恶意)的SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。
首先让我们了解什么时候可能发生SQ
- [光与电]光子信号战防御原理
comsci
原理
无论是在战场上,还是在后方,敌人都有可能用光子信号对人体进行控制和攻击,那么采取什么样的防御方法,最简单,最有效呢?
我们这里有几个山寨的办法,可能有些作用,大家如果有兴趣可以去实验一下
根据光
- oracle 11g新特性:Pending Statistics
daizj
oracledbms_stats
oracle 11g新特性:Pending Statistics 转
从11g开始,表与索引的统计信息收集完毕后,可以选择收集的统信息立即发布,也可以选择使新收集的统计信息处于pending状态,待确定处于pending状态的统计信息是安全的,再使处于pending状态的统计信息发布,这样就会避免一些因为收集统计信息立即发布而导致SQL执行计划走错的灾难。
在 11g 之前的版本中,D
- 快速理解RequireJs
dengkane
jqueryrequirejs
RequireJs已经流行很久了,我们在项目中也打算使用它。它提供了以下功能:
声明不同js文件之间的依赖
可以按需、并行、延时载入js库
可以让我们的代码以模块化的方式组织
初看起来并不复杂。 在html中引入requirejs
在HTML中,添加这样的 <script> 标签:
<script src="/path/to
- C语言学习四流程控制if条件选择、for循环和强制类型转换
dcj3sjt126com
c
# include <stdio.h>
int main(void)
{
int i, j;
scanf("%d %d", &i, &j);
if (i > j)
printf("i大于j\n");
else
printf("i小于j\n");
retu
- dictionary的使用要注意
dcj3sjt126com
IO
NSDictionary *dict = [NSDictionary dictionaryWithObjectsAndKeys:
user.user_id , @"id",
user.username , @"username",
- Android 中的资源访问(Resource)
finally_m
xmlandroidStringdrawablecolor
简单的说,Android中的资源是指非代码部分。例如,在我们的Android程序中要使用一些图片来设置界面,要使用一些音频文件来设置铃声,要使用一些动画来显示特效,要使用一些字符串来显示提示信息。那么,这些图片、音频、动画和字符串等叫做Android中的资源文件。
在Eclipse创建的工程中,我们可以看到res和assets两个文件夹,是用来保存资源文件的,在assets中保存的一般是原生
- Spring使用Cache、整合Ehcache
234390216
springcacheehcache@Cacheable
Spring使用Cache
从3.1开始,Spring引入了对Cache的支持。其使用方法和原理都类似于Spring对事务管理的支持。Spring Cache是作用在方法上的,其核心思想是这样的:当我们在调用一个缓存方法时会把该方法参数和返回结果作为一个键值对存放在缓存中,等到下次利用同样的
- 当druid遇上oracle blob(clob)
jackyrong
oracle
http://blog.csdn.net/renfufei/article/details/44887371
众所周知,Oracle有很多坑, 所以才有了去IOE。
在使用Druid做数据库连接池后,其实偶尔也会碰到小坑,这就是使用开源项目所必须去填平的。【如果使用不开源的产品,那就不是坑,而是陷阱了,你都不知道怎么去填坑】
用Druid连接池,通过JDBC往Oracle数据库的
- easyui datagrid pagination获得分页页码、总页数等信息
ldzyz007
var grid = $('#datagrid');
var options = grid.datagrid('getPager').data("pagination").options;
var curr = options.pageNumber;
var total = options.total;
var max =
- 浅析awk里的数组
nigelzeng
二维数组array数组awk
awk绝对是文本处理中的神器,它本身也是一门编程语言,还有许多功能本人没有使用到。这篇文章就单单针对awk里的数组来进行讨论,如何利用数组来帮助完成文本分析。
有这么一组数据:
abcd,91#31#2012-12-31 11:24:00
case_a,136#19#2012-12-31 11:24:00
case_a,136#23#2012-12-31 1
- 搭建 CentOS 6 服务器(6) - TigerVNC
rensanning
centos
安装GNOME桌面环境
# yum groupinstall "X Window System" "Desktop"
安装TigerVNC
# yum -y install tigervnc-server tigervnc
启动VNC服务
# /etc/init.d/vncserver restart
# vncser
- Spring 数据库连接整理
tomcat_oracle
springbeanjdbc
1、数据库连接jdbc.properties配置详解 jdbc.url=jdbc:hsqldb:hsql://localhost/xdb jdbc.username=sa jdbc.password= jdbc.driver=不同的数据库厂商驱动,此处不一一列举 接下来,详细配置代码如下:
Spring连接池  
- Dom4J解析使用xpath java.lang.NoClassDefFoundError: org/jaxen/JaxenException异常
xp9802
用Dom4J解析xml,以前没注意,今天使用dom4j包解析xml时在xpath使用处报错
异常栈:java.lang.NoClassDefFoundError: org/jaxen/JaxenException异常
导入包 jaxen-1.1-beta-6.jar 解决;
&nb