果粉必看!苹果Mac Studio上各种接口都有啥用?不会用就浪费啦
苹果新一代“造梦引擎”Mac Studio自上市以来,就深受全世界苹果发烧友的喜爱。其搭载苹果M1 Ultra芯片,另外提供M1 Max芯片版本,整机小巧而强悍,性能直触天花板。
除了扎实的硬件堆料外,这款“造梦引擎”的端口配置颇为丰富,足以搞定用户的各种扩展需求,比如说:雷雳4接口,能够完全完美适配 Studio Display 显示器,帮助用户将任何空间打造成强大的创意工作室。
不过,很多初次接触苹果Mac Studio机型的用户,对于其各种接口的用途恐怕都是一知半解!本篇文章就来跟大家具体聊一聊:
机身正面:
【M1 Max 机型】两个 USB-C 端口(速率10Gb/s),一个 SDXC 卡槽
【M1 Ultra 机型】两个雷雳 4 端口(速率40Gb/s),一个 SDXC 卡槽
位于机身正面的端口,插拔轻松,方便移动硬盘、相机存储卡等设备的使用。
机身背面:
4个雷雳 4 端口
,速率最高可达 40Gb/s,并且支持DisplayPort、USB 4及USB 3.1 等 协议;
1个10Gb 以太网端口
,Nbase-T 以太网标准,支持1Gb、2.5Gb、5Gb 和 10Gb 以太网;
2个USB-A 端口
,速率最高可达 5Gb/s,方便连接有线键鼠、移动硬盘等各种USB外设;
1个HDMI端口
,支持4K (60Hz) 最高分辨率及多声道音频输出,一般用于连接外置显示器、投影仪等设备;
1个3.5mm音频插孔
,支持连接高阻抗耳机或输出音频到功放扬声器。
值得一提的是,得益于丰富而强悍的端口加持,苹果Mac Studio最多可同时支持五台显示设备,即支持最多4台通过 USB-C 连接的Pro Display XDR(6K 分辨率、60Hz)和1台通过 HDMI 连接的 4K 显示器(6K 分辨率、60Hz),并且均支持超过十亿色彩。)
看到这里,相信大家对于苹果Mac Studio上各种接口已经有了比较全面的认识,新机到手后也就知道如何使用了!当然,如果大家使用的是轻薄笔记本电脑,经常遇到接口不够用的情况,可以通过USB扩展配件来解决需求哦。
好了,以上就是今天的分享了。如果大家对于本篇内容不同的见解,欢迎在评论区留言探讨!
从0开始实现一个NBA赛事直播新闻小程序(含后台接口)
从零开始实现一个NBA赛事直播新闻小程序切含后台接口的编写,接口来源是分析体育H5端的接口,使用php对接口进行抓取整理,切对接口进行了签名校验,已经实现,但没有用上小程序之中通过,接口整理一开始使用的是ThinkPHP5对接口统一整理的、后面使用PhalAPi对接口文档进行了再次的整理,整理的接口有以下,通过以下接口数据完成一个简单的大气的NBA小程序的开发
写在前面的一段话
关于NBA、基于深刻的莫过于高中时代的,买篮球先锋报、用手机2G网络和同学凑在一起看文字直播、还生怕班主任老师发现,
印象中第一次了解NBA是在2006年的英语书上,有一页上面是所有球队的logo以及名字、那时开始慢慢的了解篮球、了解到了休斯顿火箭队大姚、
从此对火箭队情有独钟、时至今日依然对那支22连胜的火箭有太多感情、时至今日绿军三巨头、邓肯、蜗壳都已经退役了,oh~oh~oh好像有点跑题了,还是回到主题、记录花了几天时间写的这个小程序
话不多少先上源码地址
小程序GitHub地址: https://github.com/ecitlm/wx-nba
后端接口API地址:可先参照 https://ecitlm.github.io/TP5_Splider/#/?id=tp5_splider
项目下面的 controller 下的Nba.php类
部分界面效果体验
关于接口API
接口来源是分析腾*体育H5端 的接口,使用php对接口进行抓取整理、切对接口进行了签名校验,已经实现,但没有用上小程序之中通过,接口整理一开始使用的是ThinkPHP5对接口统一整理的、后面使用PhalAPi对接口文档进行了再次的整理,整理的接口有以下、通过以下接口数据完成一个简单的大气的NBA小程序的开发、目前小程序正处于上架申请中。
每日赛事直播列表接口
球赛直播实时详情接口
实时数据统计接口
球队进本信息接口
球队球员阵容名单接口
球员基本信息赛季数据接口
30只球队排名数据接口
篮球快讯新闻列表接口
新闻详情接口
新闻评论数据接口
在线接口系统地址 https://wxapp.it919.cn/wx/listAllApis.php
小程序界面
界面整体有十几个、包含以上接口对应的UI界面、以下界面属于应用的截图界面
项目目录结构
项目目录结构如下
网络请求的封装
网络请求使用小程序的 wx.request+ promise+bluebird 对接口请求方法进行封装,一些列出的代码属于项目的核心代码
utils目录下的fetch.js文件所对应的方法
1234567891011121314151617181920212223242526272829
const Promise = require("./bluebird"); //为了兼容问题/** * 网络请求API接口 * @param {String} api api 根地址 * @param {String} path 请求路径 * @param {Objece} params 参数 */module.exports = function(api, path, params) {wx.showLoading({title: "加载中"});console.log(`${api}/${path}`);console.log(params);return new Promise((resolve, reject) => {wx.request({url: `${api}/${path}`,data: Object.assign({}, params), //如果这里需要合并签名时间戳参数时候可以这么写header: { "Content-Type": "json" },success: function(res) {resolve(res);wx.hideLoading();},fail: function(err) {wx.hideLoading();reject(err);}});});};
所有接口的请求放在api.js之中
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
const fetch = require("./fetch");const API_DOMAIN = "https://api.xxx.cn/api";/** * @param {String} 接口地址 * @param {Objece} params 接口参数参数 */function fetchApi(api, params) {return fetch(API_DOMAIN, api, params);}//NBA比赛直播function nab_schedule(params) {return fetchApi("Nba/schedule", params).then(res => res.data);}//直播室信息function live_detail(params) {return fetchApi("Nba/live_detail", params).then(res => res.data);}//直播内容function live_content(params) {return fetchApi("Nba/live_content", params).then(res => res.data);}//球员技术统计function technical_statistics(params) {return fetchApi("Nba/technical_statistics", params).then(res => res.data);}//球员详情function player_detail(params) {return fetchApi("Nba/player_detail", params).then(res => res.data);}//联盟排名function team_rank(params) {return fetchApi("Nba/team_rank", params).then(res => res.data);}//球队信息function team_info(params) {return fetchApi("Nba/team_info", params).then(res => res.data);}//球队阵容function Lineup(params) {return fetchApi("Nba/Lineup", params).then(res => res.data);}//新闻详情function news_info(params) {return fetchApi("Nba/news_info", params).then(res => res.data);}//NBA 新闻快讯function news_list(params) {return fetchApi("Nba/new_list", params).then(res => res.data);}//NBA新闻评论function news_comments(params) {return fetchApi("Nba/news_comments", params).then(res => res.data);}//关于我function website(params) {return fetchApi("Nba/website", params).then(res => res.data);}module.exports = {nab_schedule,live_detail,live_content,technical_statistics,player_detail,team_rank,team_info,Lineup,news_info,news_comments,news_list,website};
数据渲染问题
在对请求到的接口数据渲染的过程之中并没有遇到什么大的问题,页面布局上的事情也就没什么可讲的了,比较麻烦的事情是需要对接口返回的每个字段进行分析所对应的显示问题,这个再记录一下赛事直播界面的数据、新闻详情的数据渲染解析HTML的问题。
页面布局
小程序页面布局使用的单位是rpx,对应设计稿750px是最舒服的、rpx可以根据屏幕宽度进行自适应。规定屏幕宽为750rpx。如在 iPhone6 上,屏幕宽度为375px,共有750个物理像素,则750rpx = 375px = 750物理像素,1rpx = 0.5px = 1物理像素。
设备rpx换算px (屏幕宽度/750px换算rpx (750/屏幕宽度)iPhone51rpx = 0.42px1px = 2.34rpxiPhone61rpx = 0.5px1px = 2rpx数据绑定渲染wxml页面
12345678910111213141516171819202122232425262728293031323334353637
var app = getApp();Page({data: {list: [],footer: 0 //footer 底部导航栏切换高亮所要用到的值},onLoad: function() {this.nab_schedule("") //初始化数据},//ajax 列表请求nab_schedule: function(param) {var that = this;var params = {date: param};app.api.nab_schedule(params).then(res => {that.setData({list: res.data.data});}).catch(e => {console.error(e)});},//选择日期变化请求数据selectDate: function(e) {this.nab_schedule(e.target.dataset.time);},// 点击日期组件确定事件 bindDateChange: function(e) {this.nab_schedule(e.detail.value);}})
新闻详情页面渲染使用到了wxParse,能搞方便的解决渲染HTML转wxml的问题
模板页面用import导入、渲染HTML
12345
<import src="../wxParse/wxParse.wxml" /><view class="f8ad-6527-c0d5-3d71 wxParse"><template is="wxParse" data="{{wxParseData:article.nodes}}" /></view></view>
在接口请求成功时候对res.body进行一个操作处理,使用起来也比较简单
1234567891011121314151617181920212223242526
onLoad: function (e) {var data = {docid: e.docid || "D230QPOC0005877U"}var that = this;app.api.news_info(data).then(res => {console.log(res);that.setData({item: res.data});that.news_comments(data);if(res.data && res.data.img.length!=0){var replaceStr = "<img src=" + (res.data.img[0])['src'] + ">";res.data.body = res.data.body.replace("<!--IMG#0-->", replaceStr);}WxParse.wxParse('article', 'html', res.data.body, that, 5);}).catch(e => {console.error(e)var article = "文章已经删除";WxParse.wxParse('article', 'html', article, that, 5);});}
图片大图预览功能实现
演示:
小程序内置的图片查看放大组件wx.previewImage,使用该方法可以实现图片放大预览效果功能
1234
wx.previewImage({current: url, // 当前显示图片的http链接urls: [url] // 需要预览的图片http链接列表})
总结
小程序一直处于不温不火中、在笔者这这篇归档时、小程序已经开通内嵌网页功能、整体来说小程序还是很容易上手的、重要得多是多看文档,查找相关资料、仅以此文章记录开发体验、小应用还会持续更新、有感兴趣的小伙伴欢迎交流、源代码托管在GitHub
原文地址 https://code.it919.cn/2017/11/wx-nba-application/