{"id":80146,"date":"2024-10-14T19:59:50","date_gmt":"2024-10-14T16:29:50","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/scrollable-cards-in-ios-18-30daysofswift-41n0\/"},"modified":"2024-10-14T19:59:50","modified_gmt":"2024-10-14T16:29:50","slug":"scrollable-cards-in-ios-18-30daysofswift-41n0","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/scrollable-cards-in-ios-18-30daysofswift-41n0\/","title":{"rendered":"\u06a9\u0627\u0631\u062a\u200c\u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u062f\u0631 iOS 18 &#8211; #30DaysOfSwift"},"content":{"rendered":"<p>Summarize this content to 400 words in Persian Lang<br \/>\n            \u0631\u0648\u0632 \u0646\u0647\u0645: \u0627\u0633\u06a9\u0631\u0648\u0644 \u0635\u0627\u0641 \u0628\u0627 \u06a9\u0627\u0631\u062a \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634! \ud83c\udfb4<\/p>\n<p>\u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0646\u0647\u0645 \u0627\u0632 \u0633\u0631\u06cc #30DaysOfSwift\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06a9\u0627\u0631\u062a\u200c\u0647\u0627\u06cc Scrollable \u0631\u0627 \u062f\u0631 SwiftUI \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u0645. <\/p>\n<p>\u06a9\u0627\u0631\u062a\u200c\u0647\u0627 \u06cc\u0627 \u067e\u0634\u062a\u0647\u200c\u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0645\u062d\u062a\u0648\u0627 \u062f\u0631 \u0642\u0627\u0644\u0628\u06cc \u0628\u0635\u0631\u06cc \u062c\u0630\u0627\u0628 \u0648 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0639\u0627\u0644\u06cc \u0647\u0633\u062a\u0646\u062f. <\/p>\n<p>\u067e\u06cc\u0648\u0646\u062f \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 \u062a\u0635\u0648\u06cc\u0631<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u067e\u0634\u062a\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0627\u0641\u0642\u06cc \u0627\u0632 \u06a9\u0627\u0631\u062a \u0647\u0627 \u0628\u0633\u0627\u0632\u06cc\u0645 \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0631\u0627 \u0628\u0647 \u0646\u0645\u0627\u06cc\u0634 \u0628\u06af\u0630\u0627\u0631\u062f!<\/p>\n<p>  \u0645\u0631\u0627\u062d\u0644 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0627\u0631\u062a \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634:<\/p>\n<p>1. \u0637\u0631\u062d \u0628\u0646\u062f\u06cc \u06a9\u0627\u0631\u062a \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f:<\/p>\n<p>\u0645\u0627 \u0627\u0632 \u06cc\u06a9 ScrollView \u0628\u0627 \u06cc\u06a9 \u0645\u062d\u0648\u0631 \u0627\u0641\u0642\u06cc \u0648 \u0645\u062c\u0645\u0648\u0639\u0647\u200c\u0627\u06cc \u0627\u0632 \u06a9\u0627\u0631\u062a\u200c\u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0631\u0648\u06cc \u0622\u0646\u200c\u0647\u0627 \u0628\u06a9\u0634\u0646\u062f.<\/p>\n<p>import SwiftUI<\/p>\n<p>struct ScrollableCardsView: View {<br \/>\n    let items = [<br \/>\n        CardItem(title: &#8220;SwiftUI Essentials&#8221;, image: &#8220;swift&#8221;),<br \/>\n        CardItem(title: &#8220;Mastering Combine&#8221;, image: &#8220;combine&#8221;),<br \/>\n        CardItem(title: &#8220;iOS Animations&#8221;, image: &#8220;animation&#8221;),<br \/>\n        CardItem(title: &#8220;Networking with URLSession&#8221;, image: &#8220;network&#8221;)<br \/>\n    ]\n<p>    var body: some View {<br \/>\n        VStack(alignment: .leading) {<br \/>\n            Text(&#8220;Trending Courses&#8221;)<br \/>\n                .font(.largeTitle)<br \/>\n                .fontWeight(.bold)<br \/>\n                .padding(.leading)<\/p>\n<p>            ScrollView(.horizontal, showsIndicators: false) {<br \/>\n                HStack(spacing: 20) {<br \/>\n                    ForEach(items) { item in<br \/>\n                        CardView(item: item)<br \/>\n                            .frame(width: 300, height: 200)<br \/>\n                            .shadow(radius: 5)<br \/>\n                    }<br \/>\n                }<br \/>\n                .padding()<br \/>\n            }<br \/>\n        }<br \/>\n    }<br \/>\n}<\/p>\n<p>struct CardView: View {<br \/>\n    let item: CardItem<\/p>\n<p>    var body: some View {<br \/>\n        ZStack {<br \/>\n            Image(item.image)<br \/>\n                .resizable()<br \/>\n                .aspectRatio(contentMode: .fill)<br \/>\n                .frame(width: 300, height: 200)<br \/>\n                .clipped()<\/p>\n<p>            VStack {<br \/>\n                Spacer()<br \/>\n                Text(item.title)<br \/>\n                    .font(.headline)<br \/>\n                    .padding()<br \/>\n                    .frame(maxWidth: .infinity)<br \/>\n                    .background(Color.black.opacity(0.7))<br \/>\n                    .foregroundColor(.white)<br \/>\n            }<br \/>\n        }<br \/>\n        .cornerRadius(15)<br \/>\n    }<br \/>\n}<\/p>\n<p>struct CardItem: Identifiable {<br \/>\n    var id = UUID()<br \/>\n    var title: String<br \/>\n    var image: String<br \/>\n}<\/p>\n<p>struct ContentView: View {<br \/>\n    var body: some View {<br \/>\n        ScrollableCardsView()<br \/>\n    }<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0686\u06af\u0648\u0646\u0647 \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0634\u0645\u0627 \u0645\u06cc \u06af\u0631\u062f\u062f\u061f \u0628\u0647 \u0645\u0646 \u0647\u0645 \u062e\u0628\u0631 \u0628\u062f\u0647!<\/p>\n<p>\u06a9\u062f \u0646\u0648\u06cc\u0633\u06cc \u0645\u0628\u0627\u0631\u06a9!<\/p>\n<div data-article-id=\"2037833\" id=\"article-body\">\n<p>\u0631\u0648\u0632 \u0646\u0647\u0645: \u0627\u0633\u06a9\u0631\u0648\u0644 \u0635\u0627\u0641 \u0628\u0627 \u06a9\u0627\u0631\u062a \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634! \ud83c\udfb4<\/p>\n<p>\u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0646\u0647\u0645 \u0627\u0632 \u0633\u0631\u06cc #30DaysOfSwift\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06a9\u0627\u0631\u062a\u200c\u0647\u0627\u06cc Scrollable \u0631\u0627 \u062f\u0631 SwiftUI \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u0645. <\/p>\n<p>\u06a9\u0627\u0631\u062a\u200c\u0647\u0627 \u06cc\u0627 \u067e\u0634\u062a\u0647\u200c\u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0645\u062d\u062a\u0648\u0627 \u062f\u0631 \u0642\u0627\u0644\u0628\u06cc \u0628\u0635\u0631\u06cc \u062c\u0630\u0627\u0628 \u0648 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0639\u0627\u0644\u06cc \u0647\u0633\u062a\u0646\u062f. <\/p>\n<p>\u067e\u06cc\u0648\u0646\u062f \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 \u062a\u0635\u0648\u06cc\u0631<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u067e\u0634\u062a\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0627\u0641\u0642\u06cc \u0627\u0632 \u06a9\u0627\u0631\u062a \u0647\u0627 \u0628\u0633\u0627\u0632\u06cc\u0645 \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0631\u0627 \u0628\u0647 \u0646\u0645\u0627\u06cc\u0634 \u0628\u06af\u0630\u0627\u0631\u062f!<\/p>\n<h2>\n<p>  \u0645\u0631\u0627\u062d\u0644 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0627\u0631\u062a \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634:<br \/>\n<\/h2>\n<p><strong>1. \u0637\u0631\u062d \u0628\u0646\u062f\u06cc \u06a9\u0627\u0631\u062a \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f:<\/strong><\/p>\n<ul>\n<li>\u0645\u0627 \u0627\u0632 \u06cc\u06a9 ScrollView \u0628\u0627 \u06cc\u06a9 \u0645\u062d\u0648\u0631 \u0627\u0641\u0642\u06cc \u0648 \u0645\u062c\u0645\u0648\u0639\u0647\u200c\u0627\u06cc \u0627\u0632 \u06a9\u0627\u0631\u062a\u200c\u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0631\u0648\u06cc \u0622\u0646\u200c\u0647\u0627 \u0628\u06a9\u0634\u0646\u062f.\n<\/li>\n<\/ul>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight plaintext\"><code>import SwiftUI\n\nstruct ScrollableCardsView: View {\n    let items = [\n        CardItem(title: \"SwiftUI Essentials\", image: \"swift\"),\n        CardItem(title: \"Mastering Combine\", image: \"combine\"),\n        CardItem(title: \"iOS Animations\", image: \"animation\"),\n        CardItem(title: \"Networking with URLSession\", image: \"network\")\n    ]\n\n    var body: some View {\n        VStack(alignment: .leading) {\n            Text(\"Trending Courses\")\n                .font(.largeTitle)\n                .fontWeight(.bold)\n                .padding(.leading)\n\n            ScrollView(.horizontal, showsIndicators: false) {\n                HStack(spacing: 20) {\n                    ForEach(items) { item in\n                        CardView(item: item)\n                            .frame(width: 300, height: 200)\n                            .shadow(radius: 5)\n                    }\n                }\n                .padding()\n            }\n        }\n    }\n}\n\nstruct CardView: View {\n    let item: CardItem\n\n    var body: some View {\n        ZStack {\n            Image(item.image)\n                .resizable()\n                .aspectRatio(contentMode: .fill)\n                .frame(width: 300, height: 200)\n                .clipped()\n\n            VStack {\n                Spacer()\n                Text(item.title)\n                    .font(.headline)\n                    .padding()\n                    .frame(maxWidth: .infinity)\n                    .background(Color.black.opacity(0.7))\n                    .foregroundColor(.white)\n            }\n        }\n        .cornerRadius(15)\n    }\n}\n\nstruct CardItem: Identifiable {\n    var id = UUID()\n    var title: String\n    var image: String\n}\n\nstruct ContentView: View {\n    var body: some View {\n        ScrollableCardsView()\n    }\n}\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0686\u06af\u0648\u0646\u0647 \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0634\u0645\u0627 \u0645\u06cc \u06af\u0631\u062f\u062f\u061f \u0628\u0647 \u0645\u0646 \u0647\u0645 \u062e\u0628\u0631 \u0628\u062f\u0647!<\/p>\n<p>\u06a9\u062f \u0646\u0648\u06cc\u0633\u06cc \u0645\u0628\u0627\u0631\u06a9!<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>Summarize this content to 400 words in Persian Lang \u0631\u0648\u0632 \u0646\u0647\u0645: \u0627\u0633\u06a9\u0631\u0648\u0644 \u0635\u0627\u0641 \u0628\u0627 \u06a9\u0627\u0631\u062a \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634! \ud83c\udfb4 \u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0646\u0647\u0645 \u0627\u0632 \u0633\u0631\u06cc #30DaysOfSwift\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06a9\u0627\u0631\u062a\u200c\u0647\u0627\u06cc Scrollable \u0631\u0627 \u062f\u0631 SwiftUI \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u0645. \u06a9\u0627\u0631\u062a\u200c\u0647\u0627 \u06cc\u0627 \u067e\u0634\u062a\u0647\u200c\u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0645\u062d\u062a\u0648\u0627 \u062f\u0631 \u0642\u0627\u0644\u0628\u06cc \u0628\u0635\u0631\u06cc \u062c\u0630\u0627\u0628 \u0648 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0639\u0627\u0644\u06cc \u0647\u0633\u062a\u0646\u062f. \u067e\u06cc\u0648\u0646\u062f \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 \u062a\u0635\u0648\u06cc\u0631 \u0628\u06cc\u0627\u06cc\u06cc\u062f &hellip;<\/p>\n","protected":false},"author":2,"featured_media":80147,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-80146","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/80146","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=80146"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/80146\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/80147"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=80146"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=80146"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=80146"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}