【JavaScript】原生js实现省市区联动效果

这篇具有很好参考价值的文章主要介绍了【JavaScript】原生js实现省市区联动效果。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

😉博主:初映CY的前说(前端领域) ,📒本文核心:用原生js实现省市区联动

【前言】今日在复习省市县三级联动的时候,有点忘了原生的js应该怎么样处理省市县的联动,特此写下来再次复习下

⭐实现思路

  • 1.获取相对应的DOM对象
  • 2.写省市县接口获取到接口信息
  • 3.写下change事件,有变化时调用接口

⭐思路转化为代码

1.获取相对应的DOM对象

首先的话,我们先写一下静态的页面结构
(以下是关键代码)

            <div class="row mb-3">
              <label class="col-sm-2 col-form-label-sm">籍贯</label>
              <div class="col-sm-3">
                <select class="form-select form-select-sm" name="province">
                  <option selected value="">----</option>
                </select>
              </div>
              <div class="col-sm-3">
                <select class="form-select form-select-sm" name="city">
                  <option selected value="">----</option>
                </select>
              </div>
              <div class="col-sm-3">
                <select class="form-select form-select-sm" name="county">
                  <option selected value="">--/--</option>
                </select>
              </div>
            </div>

用js获取相对应的DOM

//   三省联动dom节点的获取
const province = document.querySelector('[name="province"]')
const city = document.querySelector('[name="city"]')
const county = document.querySelector('[name="county"]')

2.写省市县接口获取到接口信息

const getProvince = async () => {
    const { data } = await axios.get('/geo/province')
    console.log(data);
    province.innerHTML = `<option value=""> --省份-- </option>` + data.map(item => `<option value="${item}"> ${item} </option>`).join('')
}
const getCity = async () => {
    const { data } = await axios.get(`/geo/city?pname=${province.value}`)
    console.log(data);
    city.innerHTML = `<option value=""> --市-- </option>` + data.map(item => `<option value="${item}"> ${item} </option>`).join('')
}
const getCounty = async () => {
    const { data } = await axios.get(`/geo/county?pname=${province.value}&cname=${city.value}`)
    console.log(data);
    county.innerHTML = `<option value=""> --区/县-- </option>` + data.map(item => `<option value="${item}"> ${item} </option>`).join('')
}

注意点:option的值是通过value获取,map需要与joio一起使用(map返回值是产生新的数组,join将与其拼接)

3.写下change事件,有变化时调用接口

//  change事件
province.addEventListener('change', function () {
    getCity()
    county.innerHTML = `<option value=""> --区/县-- </option>`
})
// 市change事件
city.addEventListener('change', function () {
    getCounty()
})

注意点:注意联级调用,一层层的触发的呦。

⭐ 效果查看

【JavaScript】原生js实现省市区联动效果

至此本文结束,愿你有所收获!
期待大家的关注与支持! 你的肯定是我更新的最大动力!!!文章来源地址https://www.toymoban.com/news/detail-424122.html

到了这里,关于【JavaScript】原生js实现省市区联动效果的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包