导航:首页 > 编程语言 > js上下结构图

js上下结构图

发布时间:2025-06-21 15:59:02

1. 涓轰粈涔圝S涓鏁板肩被鍨嬪凡缁忓彲浠ヤ娇鐢∟umber鏂规硶锛岃繕瑕佸紩鍏Number瀵硅薄姒傚康锛

JavaScript涓锛屾暟鍊肩被鍨嬫湁涓ょ嶈〃绀烘柟寮忥細鐩存帴閲忓拰Number瀵硅薄銆傝繖涓ょ嶈〃绀烘柟寮忓湪澶у氭暟鎯呭喌涓嬫槸绛変环鐨勶紝浣嗘槸瀹冧滑鏈変竴浜涢噸瑕佺殑鍖哄埆銆
鐩存帴閲忥紙涔熺О涓哄師濮嬪硷級琛ㄧず涓涓鏁板煎父閲忥紝瀹冪洿鎺ュ啓鍦ㄤ唬鐮佷腑锛屼緥濡10鎴栬3.14銆傜洿鎺ラ噺鏄涓嶅彲鍙樼殑锛屽畠浠鏄鍘熷嬬被鍨嬬殑鍊硷紝涓嶈兘璋冪敤鏂规硶锛屽彧鑳借繘琛屽熀鏈鐨勮繍绠椼
Number瀵硅薄琛ㄧず涓涓鏁板硷紝浣嗘槸瀹冩槸涓涓瀵硅薄锛岃屼笉鏄鍘熷嬬被鍨嬬殑鍊笺侼umber瀵硅薄鍙浠ヨ皟鐢ㄦ柟娉曟潵鎵ц屾洿楂樼骇鐨勬搷浣滐紝姣斿傝浆鎹涓哄瓧绗︿覆銆佹瘮杈冨ぇ灏忕瓑銆備絾鏄锛岀敱浜嶯umber瀵硅薄鏄鍙鍙樼殑锛屾墍浠ュ畠鐨勬ц兘瑕佹瘮鐩存帴閲忓樊涓浜涖
鎵浠ワ紝閫氬父鏉ヨ达紝鎴戜滑搴旇ヤ紭鍏堜娇鐢ㄧ洿鎺ラ噺鏉ヨ〃绀烘暟鍊硷紝鍙鏈夊湪闇瑕佷娇鐢∟umber瀵硅薄鐨勬柟娉曟椂鎵嶄娇鐢∟umber瀵硅薄銆
瀵逛簬涓婇潰鐨勪緥瀛愶紝n1鍜宯2涓よ呴兘鍙浠ヨ皟鐢╰oString()鏂规硶鏉ュ皢鏁板艰浆鎹涓哄瓧绗︿覆锛屼絾鏄痭2鏄涓涓狽umber瀵硅薄锛屾墍浠ュ畠鍙浠ヨ皟鐢ㄦ洿澶氱殑鏂规硶銆備緥濡傦紝浣跨敤Number.isInteger()鏂规硶妫鏌ヤ竴涓鏁板兼槸鍚︿负鏁存暟鏃讹紝n1鏄鐩存帴閲忥紝鎵浠ュ畠鍙浠ョ洿鎺ヤ紶鍏`Number
鍙﹀栵紝鐢变簬Number.isInteger()鏂规硶鏄疦umber瀵硅薄鐨勪竴涓闈欐佹柟娉曪紝鑰屼笉鏄瀹炰緥鏂规硶锛屾墍浠ュ畠鏃犳硶鐩存帴鍦∟umber瀵硅薄瀹炰緥涓婅皟鐢ㄣ備緥濡傦紝鍦ㄤ笂闈㈢殑渚嬪瓙涓锛孨umber.isInteger(n1)杩斿洖true锛屽洜涓簄1鏄涓涓鐩存帴閲忥紝瀹冨彲浠ョ洿鎺ヤ紶鍏Number.isInteger()鏂规硶锛涜孨umber.isInteger(n2)杩斿洖false锛屽洜涓簄2鏄涓涓狽umber瀵硅薄瀹炰緥锛岃屼笉鏄鐩存帴閲忥紝瀹冧笉鑳界洿鎺ヤ紶鍏Number.isInteger()鏂规硶銆

鎬讳箣锛岀洿鎺ラ噺鍜孨umber瀵硅薄涓よ呴兘鍙浠ヨ〃绀烘暟鍊硷紝浣嗘槸瀹冧滑鏈変竴浜涢噸瑕佺殑鍖哄埆锛屽簲璇ユ牴鎹瀹為檯鎯呭喌鏉ラ夋嫨浣跨敤鍝绉嶆柟寮忋傞氬父鏉ヨ达紝鎴戜滑搴旇ヤ紭鍏堜娇鐢ㄧ洿鎺ラ噺鏉ヨ〃绀烘暟鍊硷紝鍙鏈夊湪闇瑕佷娇鐢∟umber瀵硅薄鐨勬柟娉曟椂鎵嶄娇鐢∟umber瀵硅薄銆

2. 在Vue中如何使用jsX,就这么简单!

JSX是什么

JSX是一种Javascript的语法扩展,JSX=Javascript+XML,即在Javascript里面写XML,因为JSX的这个特性,所以他即具备了Javascript的灵活性,同时又兼具html的语义化和直观性。(个人建议灵活度强的部分组件可以用JSX来代替,整个项目JSX属实没必要)

XML学习地址(学与不学可随意,了解就ok):https://www.w3school.com.cn/xml/index.asp

用template的弊端:https://www.mk2048.com/blog/blog\_h1c2c22ihihaa.html

为什么要在Vue中使用JSX

有时候,我们使用渲染函数(renderfunction)来抽象组件,渲染函数不是很清楚的参见官方文档,而渲染函数有时候写起来是非常痛苦的,所以只需要有个了解。

渲染函数:https://cn.vuejs.org/v2/guide/render-function.html#%E5%9F%BA%E7%A1%80

createElement('anchored-heading',{props:{level:1}},[createElement('span','Hello'),'world!'])

其对应的模板是下面:

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>

你看这写起来多费劲,这个时候就派上JSX上场了。在Vue中使用JSX,需要使用Babel插件,它可以让我们回到更接近于模板的语法上,接下来就让我们一起开始在Vue中写JSX吧。

创建项目并配置Babelvuecreatevue-jsx#选择vue2的

安装依赖:

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props

配置.babelrc(babel.config.js):

mole.exports={presets:['@vue/cli-plugin-babel/preset',['@vue/babel-preset-jsx',{'injectH':false}]]}

配置后我们启动项目:

yarnserve

demo结构图:

配置了babel.config.js后,我们把App.vue引入的HelloWorld.vue改为HelloWorld.js,并且删除HelloWorld.js中关于template和style,以及script标签。

exportdefault{name:'HelloWorld',props:{msg:String}}JSX基础用法

这里展示在Vue中书写一些基础内容。

纯文本、动态内容、标签使用、自定义组件、样式和class

importmyComponentfrom'./myComponent'import'./HelloWorld.css'//创建一个组件buttonconstButtonCounter={name:"button-counter",props:["count"],methods:{onClick(){this.$emit("change",this.count+1);}},render(){return(<buttononClick={this.onClick}>数量{this.count}+</button>);}};exportdefault{name:'HelloWorld',components:{myComponent},data(){return{text:'hello纸没了飞机',inputText:'我吃了',count:0}},props:{msg:String},watch:{},methods:{onChange(val){this.count=val;alert(this.count)}},render(){//const{text,inputText,count}=this//通过解构,下方return片段中就不需要thisreturn(<div><h3>内容</h3>{/*纯文本*/}<p>hello,IamGopal</p>{/*动态内容*/}<p>{this.text}</p><p>hello{this.msg}</p>{/*输入框*/}<input/>{/*自定义组件*/}<myComponent/><ButtonCounterstyle={{marginTop:"10px"}}count={this.count}type="button"onChange={this.onChange}/></div>);}}

题外话:创建组件那里大家可以多学学const创建的ButtonCounter组件的那种方式。在React中也是经常会这么创建的。

这么看的话和在template里写没有多大区别,标签该是啥还是啥没有变化。那么这么一想的话,style呢,class呢?接下来就是style和class样式的写法(包括动态样式)

我们先给h3绑定一个class为colorRed:

<h3class="colorRed">内容</h3>

审查元素发现直接写class绑定是可以的:

那么class的样式怎么写呢?毕竟js文件里写

貌似是不行的!

1、全局样式

App.vue

<style>.colorRed{color:red;}</style>

2、引入一个css文件或者配合style-loader引入一个less、sass、stylus文件

注意:都需要安装配置对应的loader,既然都是JSX了,那我们用stylus来讲解下,相信less、sass大家都会了。stylus是一个省略了{},靠缩紧来识别的css编译器。(不想用stylus可跳过,样式这块可随意)

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>0

各种style安装见:https://www.cnblogs.com/jimc/p/10265198.html

安装完成后新建HelloWorld.styl,然后引入。

stylus的使用:https://www.jianshu.com/p/5fb15984f22d

stylus官网:https://stylus.z.site/

控制台stylus报错见:https://blog.csdn.net/csdn\_zhoushengnan/article/details/109448369

vscode编辑期报错:安装编辑器stylus语法插件,并重启

效果:

行内样式style:

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>1

动态绑定class和style

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>2

属性绑定和普通HTML一样的

毕竟class和style可都是html的属性,这点相信大家都知道的。

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>3

效果:

常用指令

template常用指令:v-html|v-text、v-if、v-for、v-modal等。template的指令在JSX是无法使用的,故需要一些写法,请看下面。

我新建个instructions.js用来示范指令这块。在App.vue中引入。

v-html|v-text

在JSX里面,如果要设置dom元素的innerHTML,就用到domProps。

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>4

虽然v-text有domPropsInnerText,但没有用的必要。

v-if

分简单的和复杂的。

简单:

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>5

复杂:

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>6

v-for

就使用map方法来实现,在react中也是如此。

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>7

v-modal

注意:新版vue-cli4中,已经默认集成了JSX语法对v-model的支持,可以直接使用

如果你的项目比较老,也可以安装插件babel-plugin-jsx-v-model来进行支持

我可是cli4,我来验证下:

验证结果:(通过)

当然以上两种方式你都不想搞,你也可以手动支持,这就涉及到监听事件了,请向下看。

监听事件及事件修饰符

监听事件想到用onChange,onClick等。需要注意的是,传参数不能使用onClick={this.removePhone(params)},这样子会每次render的时候都会自动执行一次方法应该使用bind,或者箭头函数来传参

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>8

上面提到的用过监听事件来实现v-modal

<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>9

除此之外,还可以使用对象的方式去监听事件:

vuecreatevue-jsx#选择vue2的0

其他事件的使用同理都是加on。

事件修饰符

和指令一样,除了个别的之外,大部分的事件修饰符都无法在JSX中使用,这时候你肯定已经习惯了,肯定有替代方案的。

.stop:阻止事件冒泡,在JSX中使用event.stopPropagation()来代替

.prevent:阻止默认行为,在JSX中使用event.preventDefault()来代替

.self:只当事件是从侦听器绑定的元素本身触发时才触发回调,使用下面的条件判断进行代替

vuecreatevue-jsx#选择vue2的1

.enter与keyCode:在特定键触发时才触发回调

vuecreatevue-jsx#选择vue2的2

除了上面这些修饰符之外,尤大大为了照顾我们这群CV仔,还是做了一点优化的,对于.once,.capture,.passive,.capture.once,尤大大提供了前缀语法帮助我们简化代码

vuecreatevue-jsx#选择vue2的3

如果有参数传递给方法,不能直接(参数),会在页面中立即触发,需要我在下面这种写法:

vuecreatevue-jsx#选择vue2的4

使用范围(结合第三方ui组件)

不仅仅在render函数里面使用JSX,而且还可以在methods里面返回JSX,然后在render函数里面调用这个方法。并且也可以直接使用例如elementui等ui组件。

JSX还可以直接赋值给变量、例如使用elementui的el-dialog。(您在测试该案例时记得安装elemnt)

vuecreatevue-jsx#选择vue2的5插槽

插槽就是子组件中提供给父组件使用的一个占位符,插槽分为默认插槽,具名插槽和作用域插槽,下面我依次为您带来每种在JSX中的用法与如何去定义插槽。

默认插槽

使用默认插槽

使用element-ui的Dialog时,弹框内容就使用了默认插槽,在JSX中使用默认插槽的用法与普通插槽的用法基本是一致的,如下代码所示:

vuecreatevue-jsx#选择vue2的6

自定义默认插槽

在Vue的实例this上面有一个属性slots,这个上面就挂载了一个这个组件内部的所有插槽,使用this.slots,这个上面就挂载了一个这个组件内部的所有插槽,使用this.slots.default就可以将默认插槽加入到组件内部。

vuecreatevue-jsx#选择vue2的7

使用:

vuecreatevue-jsx#选择vue2的8

另vShow相当于v-show,不代表别的也可以这样!

具名插槽

使用具名插槽有时候我们一个组件需要多个插槽,这时候就需要为每一个插槽起一个名字,比如element-ui的弹框可以定义底部按钮区的内容,就是用了名字为footer的插槽。

vuecreatevue-jsx#选择vue2的9

自定义具名插槽

在上节自定义默认插槽时提到了slots,对于默认插槽使用this.slots,对于默认插槽使用this.slots.default,而对于具名插槽,可以使用this.$slots.footer进行自定义。

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props0

使用:

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props1

作用域插槽

使用作用域插槽

有时让插槽内容能够访问子组件中才有的数据是很有用的,这时候就需要用到作用域插槽,在JSX中,因为没有v-slot指令,所以作用域插槽的使用方式就与模板代码里面的方式有所不同了。比如在element-ui中,我们使用el-table的时候可以自定义表格单元格的内容,这时候就需要用到作用域插槽。

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props2

自定义作用域插槽

子组件中通过{this.$scopedSlots.test({user:{name:‘纸飞机’}})}指定插槽的名称是test,并将user传递给父组件。父组件在书写子组件标签的时候,通过scopedSlots值指定插入的位置是test,并在回调函数获取到子组件传入的user值

注意:作用域插槽是写在子组件标签中的,类似属性。而不是像具名插槽放在标签内部

新建个作用域插槽.js

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props3

效果:

函数式组件

函数式组件是一个无状态、无实例的组件,详见官网说明,新建一个FunctionalComponent.js文件,内容如下:

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props4

HelloWorld.js中使用:

npminstall@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props#oryarnadd@vue/babel-preset-jsx@vue/babel-helper-vue-jsx-merge-props5

效果:

代码地址

https://codechina.csdn.net/qq\_32442973/vue2-jsx-demo.git

后记

无论你是要用vue2的jsx还是vue3的jsx都没有本质区别,毕竟vue3是向下兼容vue2的;倘若你真的要学vue3的JSX,我建议你学完vue2的再去学;另我不推荐在vue中所有的组件和页面都用JSX,两者需要权衡利弊;同时也不必担心JSX和template的相互嵌套,两者是可以互相嵌套的。

参考:

https://www.cnblogs.com/ainyi/p/13324222.html

https://www.jb51.net/article/205764.htm

https://cn.vuejs.org/v2/guide/render-function.html#事件-amp-按键修饰符

https://www.cnblogs.com/htoooth/p/6973238.html

https://www.jianshu.com/p/84b708c80598

https://cloud.tencent.com/developer/article/1704608

作者:纸飞机。

3. 如何用JS点击超链接弹出对话框

1、在抄body里面布局,把对话框的大致结构写出来。

阅读全文

与js上下结构图相关的资料

热点内容
ps3游戏去什么网站下载 浏览:613
想学编程从哪里学最好 浏览:328
java音频文件加密 浏览:154
excel跨文件批量汇总数据 浏览:397
sql数据中哪些字段适合建索引 浏览:618
word页码奇偶页设置 浏览:251
华强北网站推广如何做 浏览:881
手机转app怎么用微信收款 浏览:741
怎么通过微信传app给别人 浏览:601
全光网络的发展 浏览:807
网络上果园是什么 浏览:606
为什么连接不了五g网络 浏览:365
宜搜去广告永不升级 浏览:302
哪些211计算机编程好的 浏览:369
编程公司都有哪些 浏览:359
有哪些基础的编程软件 浏览:202
笔记本网络连接空的怎么解决 浏览:307
js执行点击一个按钮 浏览:84
低龄段怎么编程 浏览:172
贴吧上传的文件在哪里 浏览:932

友情链接