input兼容安卓与ios分别打开相机与相册

本文介绍了一个针对iOS设备优化的图片上传组件实现细节。该组件能够根据设备类型(iOS或其他)调整其功能,包括从相册选择图片、使用相机拍摄图片以及设置文件输入的属性,如接受的文件类型和是否允许多选。通过JavaScript和jQuery,组件实现了响应式设计,确保了在不同设备上的良好用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        var ua = navigator.userAgent.toLowerCase();//获取浏览器的userAgent,并转化为小写——注:userAgent是用户可以修改的
        var isIos = (ua.indexOf('iphone') != -1) || (ua.indexOf('ipad') != -1);//判断是否是苹果手机,是则是true
        if (isIos) {
            $("#file").bind("click", function () {
                var that = this;
                open()//弹出选择项 相机  相册
                $('#myphoto').unbind().click(function () {
                    quxiao()//关闭选择弹框
                    $("#file").removeAttr("capture");
                    $("#file").click();
                    $("#file").unbind().change(function (e) {
                        if ($('#file').val() == '') {
                            return false;
                        }
                        var filePath = $(this).val();//获得上传的文件
                    })
                })
                $('#mycamera').unbind().click(function () {
                    quxiao()//关闭选择弹框
                    $("#file").attr("capture", "camera");
                    $("#file").click();
                    $("#file").unbind().change(function (e) {
                        var index = e.currentTarget.dataset.id;
                        if ($('#file').val() == '') {
                            return false;
                        }
                        var filePath = $(this).val();//获得拍好的图片
                    })
                })
            })
        } else {
            $("#file").bind("click", function () {
                var that = this;
                open()
                $('#myphoto').unbind().click(function () {
                    quxiao()
                    $("#file").attr('accept', "image/png,image/jpg,image/gif,image/JPEG")
                    $("#file").attr('multiple', "multiple");
                    $("#file").removeAttr("capture");
                    $("#file").click();
                    $("#file").unbind().change(function () {
                        if ($('#file').val() == '') {
                            return false;
                        }
                        var filePath = $(this).val();
                    })
                })
                $('#mycamera').unbind().click(function () {
                    quxiao()
                    $("#file").attr('accept', "image/*")
                    $("#file").removeAttr("multiple");
                    $("#file").attr('capture', "camera");
                    $("#file").click();
                    $("#file").unbind().change(function () {
                        if ($('#file').val() == '') {
                            return false;
                        }
                        var filePath = $(this).val();
                    })
                })
            })
        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值