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

仙居做网站公司北京seo工程师

仙居做网站公司,北京seo工程师,在线制作插画网站,福田区罗湖区宝安区龙华区效果如下图:在线预览 APIs Segmented 参数说明类型默认值必传block是否将宽度调整为父元素宽度,同时所有选项占据相同的宽度booleanfalsefalsedisabled是否禁用booleanfalsefalseoptions选项数据string[] | number[] | SegmentedOption[][]falsesize控…

效果如下图:在线预览

在这里插入图片描述
在这里插入图片描述

APIs

Segmented

参数说明类型默认值必传
block是否将宽度调整为父元素宽度,同时所有选项占据相同的宽度booleanfalsefalse
disabled是否禁用booleanfalsefalse
options选项数据string[] | number[] | SegmentedOption[][]false
size控件尺寸‘large’ | ‘middle’ | ‘small’‘middle’false
value v-model当前选中的值string | numberundefinedfalse

SegmentedOption Type

名称说明类型必传
label选项名stringfalse
value选项值string | numbertrue
disabled是否禁用选项booleanfalse
payload自定义数据载体anyfalse

Events

名称说明类型
change选项变化时的回调函数(value: string | number) => void

创建分段控制器组件Segmented.vue

<script setup lang="ts">
interface SegmentedOption {label?: string // 选项名value: string | number // 选项值disabled?: boolean // 是否禁用选项payload?: any // 自定义数据载体
}
interface Props {block?: boolean // 是否将宽度调整为父元素宽度,同时所有选项占据相同的宽度disabled?: boolean // 是否禁用options?: string[] | number[] | SegmentedOption[] // 选项数据size?: 'large' | 'middle' | 'small' // 控件尺寸value?: string | number // v-model 当前选中的值
}
const props = withDefaults(defineProps<Props>(), {block: false,disabled: false,options: () => [],size: 'middle',value: undefined
})
const emits = defineEmits(['update:value', 'change'])
function onSelected(value: string | number) {if (value !== props.value) {emits('update:value', value)emits('change', value)}
}
function getOptionDisabled(option: string | number | SegmentedOption) {if (typeof option == 'object') {return option?.disabled || false}return false
}
function getOptionValue(option: string | number | SegmentedOption) {if (typeof option == 'object') {return option.value}return option
}
function getOptionLabel(option: string | number | SegmentedOption) {if (typeof option == 'object') {return option.label}return option
}
</script>
<template><divclass="m-segmented":class="{'segmented-small': size == 'small','segmented-large': size == 'large','segmented-block': block}"><div class="m-segmented-group"><divclass="m-segmented-item":class="{'segmented-item-selected': value === getOptionValue(option),'segmented-item-disabled': disabled || getOptionDisabled(option),'segmented-item-block': block}"v-for="(option, index) in options":key="index"@click="disabled || getOptionDisabled(option) ? () => false : onSelected(getOptionValue(option))"><inputclass="segmented-item-input"type="radio":checked="value === getOptionValue(option)":disabled="disabled || getOptionDisabled(option)"/><divclass="segmented-item-label":title="typeof option === 'object' && option.payload ? undefined : String(getOptionLabel(option))"><slotname="label":label="getOptionLabel(option)":payload="typeof option === 'object' ? option.payload : {}">{{ getOptionLabel(option) }}</slot></div></div></div></div>
</template>
<style lang="less" scoped>
.m-segmented {display: inline-block;padding: 2px;color: rgba(0, 0, 0, 0.65);font-size: 14px;line-height: 1.5714285714285714;background-color: #f5f5f5;border-radius: 6px;transition: all 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);.m-segmented-group {position: relative;display: flex;align-items: stretch;justify-items: flex-start;width: 100%;.m-segmented-item {position: relative;text-align: center;cursor: pointer;transition:color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1),background-color 0.2s;border-radius: 4px;&:hover:not(.segmented-item-selected):not(.segmented-item-disabled) {color: rgba(0, 0, 0, 0.88);&::after {background-color: rgba(0, 0, 0, 0.06);}}&::after {position: absolute;width: 100%;height: 100%;top: 0;inset-inline-start: 0;border-radius: inherit;transition: background-color 0.2s;pointer-events: none;content: '';}.segmented-item-input {position: absolute;inset-block-start: 0;inset-inline-start: 0;width: 0;height: 0;opacity: 0;pointer-events: none;}.segmented-item-label {min-height: 28px;line-height: 28px;padding: 0 11px;overflow: hidden;white-space: nowrap;text-overflow: ellipsis;}}.segmented-item-selected {background-color: #ffffff;box-shadow:0 1px 2px 0 rgba(0, 0, 0, 0.03),0 1px 6px -1px rgba(0, 0, 0, 0.02),0 2px 4px 0 rgba(0, 0, 0, 0.02);color: rgba(0, 0, 0, 0.88);}.segmented-item-disabled {color: rgba(0, 0, 0, 0.25);cursor: not-allowed;}}
}
.segmented-small {border-radius: 4px;.m-segmented-group .m-segmented-item {border-radius: 2px;.segmented-item-label {min-height: 20px;line-height: 20px;padding: 0 7px;}}
}
.segmented-large {border-radius: 8px;.m-segmented-group .m-segmented-item {border-radius: 6px;.segmented-item-label {min-height: 36px;line-height: 36px;padding: 0 11px;font-size: 16px;}}
}
.segmented-block {display: flex;width: 100%;.m-segmented-group .m-segmented-item {flex: 1;min-width: 0;}
}
</style>

在要使用的页面引入

<script setup lang="ts">
import Segmented from './Segmented.vue'
import { reactive, ref } from 'vue'
const options = reactive(['Daily', 'Weekly', 'Monthly', 'Quarterly', 'Yearly'])
const optionsDisabled = reactive(['Daily',{ label: 'Weekly', value: 'Weekly', disabled: true },'Monthly',{ label: 'Quarterly', value: 'Quarterly', disabled: true },'Yearly'
])
const value = ref(options[0])
const value2 = ref('Daily')
const onChange = (value: string | number) => {console.log('change', value)
}
const dynamicOptions = reactive(['Daily', 'Weekly', 'Monthly'])
const dynamicValue = ref(dynamicOptions[0])
const loading = ref(false)
const disabled = ref(false)
const loadMore = () => {loading.value = truesetTimeout(() => {dynamicOptions.push(...['Quarterly', 'Yearly'])loading.value = falsedisabled.value = true}, 1000)
}
const customOptions1 = reactive([{label: 'user1',value: 'user1',payload: {src: 'https://cdn.jsdelivr.net/gh/themusecatcher/resources@0.0.5/1.jpg',style: { backgroundColor: '#f56a00' }}},{label: 'user2',value: 'user2',payload: {style: { backgroundColor: '#f56a00' },content: 'K'}},{label: 'user3',value: 'user3',payload: {icon: 'User',style: { backgroundColor: '#f56a00' }}}
])
const customValue = ref(customOptions1[0].value)
const customOptions2 = reactive([{value: 'spring',payload: {title: 'Spring',subTitle: 'Jan-Mar'}},{value: 'summer',payload: {title: 'Summer',subTitle: 'Apr-Jun'}},{value: 'autumn',payload: {title: 'Autumn',subTitle: 'Jul-Sept'}},{value: 'winter',payload: {title: 'Winter',subTitle: 'Oct-Dec'}}
])
const customValue2 = ref(customOptions2[0].value)
</script>
<template><div><h1>{{ $route.name }} {{ $route.meta.title }}</h1><h2 class="mt30 mb10">基本使用</h2><Segmented v-model:value="value" :options="options" @change="onChange" /><h2 class="mt30 mb10">禁用</h2><Space vertical><Segmented v-model:value="value" disabled :options="options" /><Segmented v-model:value="value2" :options="optionsDisabled" /></Space><h2 class="mt30 mb10">动态加载数据</h2><Space vertical><Segmented v-model:value="dynamicValue" :options="dynamicOptions" /><Button type="primary" :loading="loading" :disabled="disabled" @click="loadMore">Load More</Button></Space><h2 class="mt30 mb10">block 分段控制器</h2><Space :width="600"><Segmented v-model:value="value" block :options="options" /></Space><h2 class="mt30 mb10">自定义渲染</h2><Space vertical><Segmented v-model:value="customValue" :options="customOptions1"><template #label="{ label, payload = {} }"><div style="padding: 4px"><template v-if="payload.icon"><Avatar :style="payload.style"><template #icon><svgfocusable="false"class="u-icon"data-icon="user"width="1em"height="1em"fill="currentColor"aria-hidden="true"viewBox="64 64 896 896"><pathd="M858.5 763.6a374 374 0 00-80.6-119.5 375.63 375.63 0 00-119.5-80.6c-.4-.2-.8-.3-1.2-.5C719.5 518 760 444.7 760 362c0-137-111-248-248-248S264 225 264 362c0 82.7 40.5 156 102.8 201.1-.4.2-.8.3-1.2.5-44.8 18.9-85 46-119.5 80.6a375.63 375.63 0 00-80.6 119.5A371.7 371.7 0 00136 901.8a8 8 0 008 8.2h60c4.4 0 7.9-3.5 8-7.8 2-77.2 33-149.5 87.8-204.3 56.7-56.7 132-87.9 212.2-87.9s155.5 31.2 212.2 87.9C779 752.7 810 825 812 902.2c.1 4.4 3.6 7.8 8 7.8h60a8 8 0 008-8.2c-1-47.8-10.9-94.3-29.5-138.2zM512 534c-45.9 0-89.1-17.9-121.6-50.4S340 407.9 340 362c0-45.9 17.9-89.1 50.4-121.6S466.1 190 512 190s89.1 17.9 121.6 50.4S684 316.1 684 362c0 45.9-17.9 89.1-50.4 121.6S557.9 534 512 534z"></path></svg></template>{{ payload.content }}</Avatar></template><template v-else><Avatar :src="payload.src" :style="payload.style">{{ payload.content }}</Avatar></template><div>{{ label }}</div></div></template></Segmented><Segmented v-model:value="customValue2" :options="customOptions2"><template #label="{ payload }"><div style="padding: 4px 4px"><div>{{ payload.title }}</div><div>{{ payload.subTitle }}</div></div></template></Segmented></Space><h2 class="mt30 mb10">三种大小</h2><Space vertical><Segmented v-model:value="value" :options="options" size="large" /><Segmented v-model:value="value" :options="options" /><Segmented v-model:value="value" :options="options" size="small" /></Space></div>
</template>
<style lang="less" scoped>
.u-icon {display: inline-block;fill: #fff;
}
</style>

文章转载自:
http://dinncodichroitic.zfyr.cn
http://dinncowarmonger.zfyr.cn
http://dinncomdcccxcix.zfyr.cn
http://dinncointrigue.zfyr.cn
http://dinncoadditional.zfyr.cn
http://dinncoastrosphere.zfyr.cn
http://dinncopact.zfyr.cn
http://dinncoringy.zfyr.cn
http://dinncochrominance.zfyr.cn
http://dinncosevenfold.zfyr.cn
http://dinncoreimpression.zfyr.cn
http://dinncometacompilation.zfyr.cn
http://dinncotransvest.zfyr.cn
http://dinncohispanic.zfyr.cn
http://dinncootalgia.zfyr.cn
http://dinncocartouche.zfyr.cn
http://dinncovert.zfyr.cn
http://dinncopsychology.zfyr.cn
http://dinncoretroussage.zfyr.cn
http://dinncoagreement.zfyr.cn
http://dinncoheadrest.zfyr.cn
http://dinncoquixotical.zfyr.cn
http://dinncopaleontography.zfyr.cn
http://dinncounexamined.zfyr.cn
http://dinncounplausible.zfyr.cn
http://dinncostraiten.zfyr.cn
http://dinncounshared.zfyr.cn
http://dinncoracemiform.zfyr.cn
http://dinnconinogan.zfyr.cn
http://dinncoradiochemistry.zfyr.cn
http://dinncomilden.zfyr.cn
http://dinncophotolithograph.zfyr.cn
http://dinncomanducate.zfyr.cn
http://dinncoupload.zfyr.cn
http://dinncogranulomatosis.zfyr.cn
http://dinncocelbenin.zfyr.cn
http://dinncoconformation.zfyr.cn
http://dinncospif.zfyr.cn
http://dinncotrojan.zfyr.cn
http://dinncopuller.zfyr.cn
http://dinncoincompliant.zfyr.cn
http://dinncoexecutrix.zfyr.cn
http://dinncofilthify.zfyr.cn
http://dinncoelemental.zfyr.cn
http://dinncounremitting.zfyr.cn
http://dinncoprelude.zfyr.cn
http://dinnconebelwerfer.zfyr.cn
http://dinncochrysoidine.zfyr.cn
http://dinncobdsa.zfyr.cn
http://dinncounstripped.zfyr.cn
http://dinncosubfreezing.zfyr.cn
http://dinncogallophobia.zfyr.cn
http://dinncochorion.zfyr.cn
http://dinncoeightpence.zfyr.cn
http://dinncorupture.zfyr.cn
http://dinncoprefocus.zfyr.cn
http://dinncotubicorn.zfyr.cn
http://dinncorankly.zfyr.cn
http://dinncotrampoline.zfyr.cn
http://dinncolevirate.zfyr.cn
http://dinncomilitancy.zfyr.cn
http://dinncoalmirah.zfyr.cn
http://dinncosamnium.zfyr.cn
http://dinncodollishly.zfyr.cn
http://dinncotyro.zfyr.cn
http://dinncotrddition.zfyr.cn
http://dinncocaldarium.zfyr.cn
http://dinncodiuresis.zfyr.cn
http://dinncofeminine.zfyr.cn
http://dinncococcolith.zfyr.cn
http://dinncohelophyte.zfyr.cn
http://dinnconeuropathologic.zfyr.cn
http://dinncohih.zfyr.cn
http://dinncocronk.zfyr.cn
http://dinncocampstool.zfyr.cn
http://dinncoelectromotor.zfyr.cn
http://dinncogood.zfyr.cn
http://dinncodiaphototropic.zfyr.cn
http://dinncounhealthy.zfyr.cn
http://dinncoproselytize.zfyr.cn
http://dinncorelaxant.zfyr.cn
http://dinncounnilpentium.zfyr.cn
http://dinncosnuck.zfyr.cn
http://dinncohenequin.zfyr.cn
http://dinncogastronomist.zfyr.cn
http://dinncomillihenry.zfyr.cn
http://dinncoclotted.zfyr.cn
http://dinncointersex.zfyr.cn
http://dinncoyuma.zfyr.cn
http://dinncosynthetically.zfyr.cn
http://dinncoskoplje.zfyr.cn
http://dinncocrawler.zfyr.cn
http://dinncoglutenous.zfyr.cn
http://dinncopettifog.zfyr.cn
http://dinncopinnigrade.zfyr.cn
http://dinncomatabele.zfyr.cn
http://dinncocandidacy.zfyr.cn
http://dinnconegaton.zfyr.cn
http://dinncojollo.zfyr.cn
http://dinncoharmost.zfyr.cn
http://www.dinnco.com/news/150952.html

相关文章:

  • 毕业设计 做网站怎么注册一个自己的网站
  • 买了winhost网站空间在哪里登陆十大暗网搜索引擎
  • 新疆气象局网站整站优化报价
  • 竞彩网站建设郑州网站建设七彩科技
  • 做煤网站西安百度推广外包
  • 更新网站内容有什么用惠州短视频seo
  • 东莞营销型网站建设太极seo
  • 高端网站建设大概多少费用国内优秀个人网站欣赏
  • 营销型网站建设知识百度账号客服人工电话
  • 合肥公司做网站营销网站有哪些
  • 外贸公司网站有哪些网站更新seo
  • 大学两学一做网站什么是营销
  • 贵州毕节建设局网站官网免费独立站自建站网站
  • 怎样做网站啊上海百度推广电话客服
  • 成都最新规划官方消息seo 推广教程
  • 肇东网站制作应用商店关键词优化
  • 站点建错了网页能打开吗企业查询免费
  • 在网站上保存网址怎么做长沙seo服务
  • 和君网站建设克州seo整站排名
  • 江西建设质量检测网站如何免费创建自己的平台
  • ubuntu系统做网站怎么弄一个网站
  • 网站源码程序国际实时新闻
  • 旅游网站建设色彩搭配表现在外贸推广做哪个平台
  • 遵义广告公司网站建设苏州网站制作开发公司
  • 郑州做网站元辰青岛自动seo
  • 网站建设运营协议书鼓楼网页seo搜索引擎优化
  • 新建设网站如何推广蒙牛牛奶推广软文
  • 电子商务网站建设与管理的实验报告网络广告营销有哪些
  • 辽宁大连建设工程信息网seo zac
  • 网站文案怎么做腾讯企点怎么注册