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}]]}配置後我們啟動項目:
yarnservedemo結構圖:
配置了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
屬性綁定和普通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>6v-for
就使用map方法來實現,在react中也是如此。
<anchored-heading:level="1"><span>Hello</span>world!</anchored-heading>7v-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-props4HelloWorld.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裡面布局,把對話框的大致結構寫出來。