用 20+ 行 JavaScript 代码,短暂“变身” iOS 程序员!
摘要:你有没有尝试过在 iOS 中创建小部件,感受一把身为 iOS 程序员的快乐?本文作者将用二十几行 JavaScript 代码教你构建一个 iOS 小部件,据他所说,这“一点都不难”。
原文链接:https://stackonfire.com/feel-yourself-ios-developer-with-20-lines-of-javascript
声明:本文为 CSDN 翻译,未经授权,禁止转载。
作者 | Dimitri Ivashchuk
在这篇入门指南中,我们将构建如下软件,实际所需编写的 JavaScript 代码非常少。
这个软件的创意来源有两个:
1.有人使用这个小部件来显示收入。
2.频繁检查 GitHub 代码库的星星数量很麻烦。
我发现,构建 iOS 小部件一点都不难,只要有合适的工具,再加上非常基础的 JavaScript 知识即可!
项目简介
这个项目是一个 iOS 小部件,用来显示 GitHub 代码库的星星数量。这里我通过自己的一个开源项目为例进行说明。我们将采用 Scriptable,这个工具可以通过 JavaScript 生成漂亮的小部件,就像上图一样。
代码
// Request
// Nothing special here, just an async request function GitHub open API
async function getGithubData() {
const url = "https://api.github.com/repos/lost-pixel/lost-pixel";
const request = new Request(url);
const response = await request.loadJSON();
return response;
}
//UI
// Function that defines the element of the widget
async function createWidget() {
// Fetching data with the function we prepared before
const githubData = await getGithubData();
// Create new wdiget & set black background color
let listwidget = new ListWidget();
listwidget.backgroundColor = new Color("#000000");
// Create heading and style it properly
let heading = listwidget.addText("⭐ Lost Pixel ⭐");
heading.centerAlignText();
heading.font = Font.lightSystemFont(25);
heading.textColor = new Color("#fff");
// Add spacer between elements
listwidget.addSpacer(15);
// Create the stars display and style it properly. We use the data from API here
let stars = listwidget.addText(githubData.stargazers_count);
stars.centerAlignText();
stars.font = Font.semiboldSystemFont(20);
stars.textColor = new Color("#ffffff");
return listWidget;
}
// Execute createWidget function that returns us the widget
let widget = await createWidget();
// Show the widget when added to IOS homescreen
if (config.runsInWidget) {
Script.setWidget(widget);
} else {
widget.presentMedium();
}
// finish the execution of the script
Script.complete();
显示小部件
1.在 iOS 设备上安装 Scriptable for iOS;
2.点击 + 按钮创建一个新的脚本。
3. 将上面的代码粘贴到空白输入处。
4. 保存,这样就完成了!
5. 最后一步,只需将这个小部件添加到主屏幕即可:通过 Scriptable 小部件,将刚刚建好的小部件添加到主屏幕。
好了,恭喜你完成了!
☞Node 之父斥责 Oracle:你们也不用,那请交出 JavaScript 商标! ☞苹果往事:“我们必须制造 iPhone,它一定会终结 iPod” ☞JavaScript 后端开发者必须跨的 10 道门槛!
-
TIOBE 8月编程语言排行公布:Go排名第7创新高!超越JavaScript不远了
TIOBE发布了最新的2024年11月的编程语言排行榜,Go语言在TIOBE指数中的排名不断上升,本月排名已经提升至第7,创下该语言的历史新高。TIOBE CEO Paul Jansen点评称,Go在
-
jsMind 用JavaScript构建的思维导图库
jsMind的设计理念是简洁而强大。它不仅支持多种数据格式,还提供了丰富的API接口,使得开发者可以轻松地将其集成到自己的项目中。以下是jsMind的一些核心特点:纯JavaScript编写:这意味着
-
granimjs:给网页背景 元素 文字添加交互式的渐变效果
granim.js 是一个开源 JavaScript 库,专门用于创建流畅和交互式的渐变动画。这些动画可以作为网页的背景,也可以给其他元素添加渐变动画,如按钮或滑块的视觉反馈。还可以为文字加上渐变效果
关注公众号:拾黑(shiheibook)了解更多
赞助链接:
关注数据与安全,洞悉企业级服务市场:https://www.ijiandao.com/
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
随时掌握互联网精彩
- 卢布汇率人民币2023年11月16日
- 同心赋能 铸就未来|行业大咖共话央国企信创转型替代之道
- 阿里云盘会员服务有变,超大容量遭下架
- 看书对学技术的重要性;前端er工作中应该怎么提升自己;怎样才算是在写有“技术含量”的代码|极客观点
- 【划重点】一张图 Get 微软中国生态福利策略
- 硅片市场出现结构性分化
- 当“套餐”遇上“短视频”,成功解救疫情下的实体店?
- VC悄悄杀入服装赛道,红杉、高瓴、GGV密集入局,连B站也来了
- 美国哈佛大学肯尼迪学院发布《国会现代技术评估》报告
- 【周末荐书】气候经济与人类未来:比尔·盖茨给世界的解决方案
- 劳动力 · 新定义 | 数字驱动零售业劳动力管理升级
- 荣耀还能起飞吗?