PC端 API 和 移动端 API 兼容性太差了
很多代码其实就是直接改了个名字,但使用方式确变了
比如 requestAuthCode 两边都有 也都是不要配置 config 加密的,但是 PC 不能在 DingTalkPC.ready 里调用, 移动端 必须在 dd.ready 里调用
<script type="text/javascript" src="https://g.alicdn.com/dingding/open-develop/1.5.1/dingtalk.js"></script>
<script type="text/javascript" src="https://g.alicdn.com/dingding/dingtalk-pc-api/2.7.0/index.js"></script>
<script>
var requestAuthCode = function(){};
var myAuth = function() {
requestAuthCode({
corpId: '',
onSuccess: function(result) {
// TODO
},
onFail : function(err) {
// TODO
}
})
}
if (DingTalkPC.ua.isInDingTalk) {
requestAuthCode = DingTalkPC.runtime.permission.requestAuthCode;
myAuth();
// dingtalkApi.ready(myAuth); // 挂掉
} else if (dd.android || dd.ios) {
requestAuthCode = dd.runtime.permission.requestAuthCode;
// myAuth(); // 直接调用会挂
dd.ready(myAuth);
}
</script>
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
面对PC端API和移动端API的兼容性问题,确实会给开发者带来一定的困扰。针对您提到的requestAuthCode
调用场景不一致的问题,这主要是因为DingTalk(钉钉)在设计其SDK时,为了适配不同平台(PC与移动)的特性和运行环境,采取了不同的初始化和调用逻辑。
明确平台差异:首先,理解并接受不同平台(PC端、移动端)由于运行环境、用户交互方式等差异,导致API调用方式存在区别的事实。这是跨平台开发中常见的挑战。
统一接口调用层:在您的项目架构设计中,可以考虑创建一个中间层或者抽象层来封装这些平台特定的调用逻辑。这样,无论是在PC端还是移动端,上层业务代码只需要调用统一的接口,而具体到每个平台的实现细节则在这个中间层处理。
AuthenticationService
类,内部根据当前运行环境(通过UserAgent检测或直接传入环境参数)决定是调用DingTalkPC.ready
后执行requestAuthCode
还是等待dd.ready
。文档与示例:仔细阅读阿里云或钉钉官方提供的API文档和示例代码,通常它们会提供针对不同平台的最佳实践指南。确保遵循官方推荐的方式来使用API,以减少不必要的错误。
社区与支持:遇到具体问题时,可以查阅相关开发者论坛、社区,如阿里云开发者社区、钉钉开放平台社区等,看是否有其他开发者分享过类似的解决方案,或者直接向官方技术支持寻求帮助。
版本管理:注意检查使用的SDK版本,有时候新版本的SDK可能会对跨平台兼容性进行优化。保持SDK更新也是解决兼容性问题的一个途径。
模块化与解耦:尽量使你的应用模块化,将平台相关的代码隔离在独立的模块中,这样当需要调整或适配新的平台特性时,影响范围会更小,维护成本也会降低。
通过上述方法,虽然不能完全消除平台间的API差异,但可以有效地管理和减轻因兼容性问题带来的开发负担。