当前位置: 首页 > news >正文

企业公司网站制作网站源码生成器

企业公司网站制作,网站源码生成器,怎么样才能在网上卖东西,核桃编程加盟费多少钱ts类型 TS类型除了原始js类型之外&#xff0c;还增加类型&#xff0c;例如&#xff1a;枚举、接口、泛型、字面量、自定义、类型断言、any、类型声明文件 数组类型两种写法&#xff1a;类型 [] 或 Array <类型> let arr:number[][1,2,3,4] let arr:string[][a] let arr…

ts类型

TS类型除了原始js类型之外,还增加类型,例如:枚举、接口、泛型、字面量、自定义、类型断言、any、类型声明文件

数组类型两种写法:类型 [] 或 Array <类型>

let arr:number[]=[1,2,3,4]
let arr:string[]=['a']
let arr:Array <string>=['a']

需求:如果想要类型和长度都限定

1、元组类型

方法:元组-数组的类型和长度都限定,并且可以让元素有不同的类型

//语法:
let arr:[number,number]=[1,3]
let arr:[number,string]=[1,3]

2、联合类型

数组存放数字或字符串-联合类型

let arr4:(number | string)[]=[1,2,'3']

定时器为number类型

let timer:number | null=null
​
timer=setTimeout(()=>{},1000)

arr6类型是数字或字符串数组

let arr6:number | string[]=['j']

3、类型别名

type类型别名=具体类型

类型别名起名用大驼峰

type CustomType=(number | string)[]
let arr7:CustomType=[1,'2']

4、函数类型

分别指定参数和返回值的类型

普通函数
function getSum(a:number,b:number):number{
return a+b
}
函数表达式
const getSum=function(a:number,b:number):number{return a+b
}
箭头函数
const getSum=(a:number,b:number):number=>{return a+b
}

同时指定 (参数类型)=>返回值类型

const getSum:(a:number,b:number)=>number=(x,y)=>{
return x+y
}
或
type Fn=(a:number,b:number)=>number
const getSum:Fn=(a,b)=>{return a+b
}

如果函数不需要返回值.

:void可省略,如果写:undefined,必须写return undefined

const fn=():void=>{
console.log('hhhhh')
}

可选参数?就是参数可传可不传--->必须写到后面

const fn2=(b:number,num?:number)=>{
}
fn2(10)//10给b

函数上用接口---->泛型函数

function getSnum<T>(sno:T){}
const sno=getSnum<number>(1001)//约束数字型

5.对象类型

描述对象的属性和方法类型、

let obj:{}={a:1}//空对象
let obj2:{a:10}={a:10}//值为固定的、
​
let person:{name:string,age:number}={name:'zs',age:20}
//相当于
let person2:{name:stringage?:number//可选
}
={name:'zs',age:20}
​
​

6、接口

interface描述对象类型

interface
可以继承-->目的实现复用
interface Person{eat():voidsleep():void
}
interface Student{name:stringage:numberstudy:()=>void
}
let s1.Student={name:'list',age:20,study(){},eat(){},sleep(){}}type  
类型别名
type Student={name:stringage:numberstudy:()=>void
}
实现复用
type Student={name:stringage:numberstudy:()=>void
}& Person
let s1.Student={name:'list',age:20,study(){}}
​

interface和type区别

  1. 很多时候。可以自由切换

  2. interface支持对象类型,可以继承

  3. type可以支持任何类型,通过交叉类型(&)实现复用

  4. type不能重复定义,interface可以重复定义会合并

用泛型

interface Data<T>{name:stringage:numberavator:stringaddress:T
}
interface User:{
province:string
city:string
}
interface Manger{company:string
}
//用泛型简洁
let zs:Data<User>={
name:'zs'
age:90
avator:''
address:{province:'安徽',city:'黄山'}
}
​
let list:Data<Manager>={name:'zs'age:90avator:""address:{company:'PDD'
}
}
}

在接口上用泛型不同点:

  1. 接口上:interface

  2. 不需要等于号

7、类型推断

没有指定类型,ts会导出其类型

类型注解能省略就省略

变量初始化

let score=100
//函数返回值会推断类型
const myFn=(a:number,b:number)=>{
}

8、字面量

const a=1=>const a:1=1
//字面量配合联合类型,表示一组可选值
let degree:'专科' | '本科' | '研究生'='本科'
​

9、ang(不推荐使用)

作用:逃避ts,没有类型

不受类型的约束

隐式:

  • 定义没有初始值

  • 函数形参,就是any

10、类型断言

查找dom元素

ts把alink的类型推断为HTMLElement(普通的标签类型)--->前面必须是锚点连接

const link=document.getElementById('link') as HTMLElement
console.log(alink.href)

11、泛型

type User={name:stringage:numberavator:stringaddress:{city:string}
}和
type Mange={name:stringage:numberavator:stringaddress:{company:string}
}
//以上两个多的话不好复用,所以
type Data<T>={name:stringage:numberavator:stringaddress:T
}

更简洁

type User={city:string
}
type User={city:string
}
//用泛型更简洁
type Data<T>={name:stringage:numberavator:stringaddress:T
}
type UserData=Data<User>
type MangerData=Data<Manger>
​
let zs:UserData={name:'zs'age:90avator:''address:{province:'安徽',city:'黄山'}
}

12、ts与vue结合

在vi中有安装的方式

第一步安装项目

npm create vite@latest 名称 -- --template vue-ts

安装依赖:

npm i

进入项目把components和App.vue都删除

main.js保留

import { createApp } from 'vue'
// import './style.css'
import App from './App.vue'
​
createApp(App).mount('#app')
​

要把vetur禁用,要不然出报错,不过不影响

13、父传子

父亲:App.vue

<template><div><hello-world msg="hi"></hello-world></div>
</template>
​
<script setup lang="ts">import HelloWorld from './components/HelloWorld.vue';
</script>
<style>
</style>

儿子:src/components/HelloWorld.vue

<template><div>子组件<p>{{ msg }}</p></div>
</template>
​
<script setup lang="ts">
//平常写法
defineProps({msg:String
})
//用ts写的方法
<script setup lang="ts">defineProps<{msg:stringnum?:number//加上?是可选的,如果不加会错}>()
//页面上出现:hi
//默认值平常写法defineProps({msg:{type:String,default:'hello'},//设为默认,如果有值,就传,没有就不传num:Number})
//页面上出现:hello
//默认值ts写法withDefaults(defineProps<{msg:stringnum?:number}>(),{num:100})
页面上是100
</script>
​
<style>
​
</style>

14、子传父

父亲:App.vue

<template><div><hello-world :msg="msg" @change="change"></hello-world></div>
</template>
​
<script setup lang="ts">
import {ref} from 'vue'import HelloWorld from './components/HelloWorld.vue';const msg=ref('hi')const change=(v:string)=>{msg.value=v}
</script>
​
<style>
​
</style>

儿子:src/components/HelloWorld.vue

<template><div>子组件<p>{{ msg }}</p>
​<button @click="changer">修改</button></div>
</template>
​
<script setup lang="ts">withDefaults(defineProps<{msg:stringnum?:number}>(),{num:100})//e约束自定义事件名称,msg参数const emit=defineEmits<{//冒号前面拘束emit参数类型,冒号后面约束emit返回值类型(e:'change',msg:string):void
}>()const changer=()=>{emit('change','son')}
</script>
​
<style>
​
</style>

点击按钮,会把儿子传父亲

ref会根据数据自动推断类型

1、假如是简单类型、利用类型推导

const msg=ref('hi')

2、假如是引用数据类型、利用类型

type Todo={
​
id:number
​
name:string
​
donge:boolean
​
}
​
const task=ref<Todo[]>([])
​
task.value=[{id:1,name:'coding'}]
​
​

reactive的TS写法

1、默认值属性固定,可以使用类型推导

const book =reactive({title:'ts从入门到放弃',price:59})

2、类型推导的类型不符合需求,手动给变量或常量指定类型

type Book={
​title:string
​
price?:number
​
}
​
const book:Book=reactive({ttile:'5555',price:999})
​
console.log(book)

计算属性的ts怎么写--可以用类型推断或者泛型

​
//类型推导
const upperMsg=computed(()=>{
return msg.value.toUpperCase()
})
//用泛型
const upperMsg=computed<string>(()=>{
return msg.value.toUpperCase()
})

事件处理的ts

函数参数e默认推断ang类型

const handClick=(e:Event)=>{const ele=e.target as HTMLButtonElementele.disabled=
}

ref

获取dom元素,

<template><input type='text' ref='iptRef'>
</template>
const iptRef=ref<HTMLInputElement | null>(null)s
onMounted(()=>{//用生命周期挂载//类型守卫// 第一种if(iptRef.value){iptRef.value.focus()}// 第二种iptRef.value?.focus()// 第三种iptRef.value && iptRef.value.focus()//非空断言iptRef.value!.focus()
})

http://www.yayakq.cn/news/494909/

相关文章:

  • ps做电商网站尺寸是多少传媒公司 网站开发
  • 网站建设的ppt模板网站建设需要多长时间
  • 彩票网站招代理广告怎么做2345浏览器网页版入口
  • 茂名住房和城乡建设局网站淘宝网页版电脑版登录入口
  • 网站建设-丹东建设数据库网站需要哪些设备
  • 成都网站建设939网络营销策划方案内容
  • 做app封装的网站聊城网站建设lckjxx
  • 石家庄网站推广方案一个人网站开发
  • 张家港网站建设哪家好福州 网站定制设计
  • 网站开发开题报告格式创建网站的六个步骤
  • 德阳如何做百度的网站网址查询ip地址方法
  • 团购网站 备案问题flash制作动画教程
  • 一个网站开发的权限太原网页设计与制作
  • 泉州建站模板搜索引擎优化不包括
  • 浦东新区网站设计文字做图网站
  • 苏州高端网站建设kgwl中国移动官方网站
  • 网站建设丷金手指花总小程序源码开发
  • 网站的建设项目是什么意思美食分享网站怎么做
  • 大学生实训网站建设心得太原搭建网站的公司哪家好
  • 为什么很多网站在维护wordpress 获取分类子分类
  • 承德网站建设制作怎样给自己做网站
  • 盐山国外网站建设wordpress默认编辑器增强
  • 做购物网站适合的服务器通过百度指数不能判断出
  • 广州建筑公司网站北京logo设计公司哪家好
  • 知名广告公司有哪些做网站和优化共多少钱
  • 如何编写网站开发文档上海企业营销型网站建设
  • dedecms网站模板免费下载加拿大计划网站怎么做
  • 商业网站有哪些织梦网站怎么更换模板
  • 永久免费素材网站苏州工业园区发布
  • 为什么做视频网站违法平面设计做画册用网站