我试图为日历类型的应用程序制作一天选择器 但由于某种原因选择一天不起作用。(我对代码中断的位置有评论 )(acalendar i

我试图为日历类型的应用程序制作一天选择器,但由于某种原因选择一天不起作用。(我对代码中断的位置有意见)。

我试图为日历类型的应用程序制作一天选择器,但由于某种原因选择一天不起作用。(我对代码中断的位置有意见)。

问题是变量 selectedDate 不更新。

Basically the code has a loop from 0 to 100 days, and I just multiply current date by the iterator to get 100 future dates. I need the code to change selectedDate to whatever date I pick from the listenter image description here

我有这两个变量来跟踪:

@State var currentDate = Date()
@State var selectedDate = Date()

(我认为问题来自我使用 ForEach 循环,但我不确定)

ForEach(0..<100) { day in
                                
                                if (selectedDate == (currentDate + TimeInterval((86400 * day)))) {
                                    Button {
                                        selectedDate = (currentDate + TimeInterval((86400 * day)))
                                        // error here
                                    } label: {
                                        
                                        ZStack {
                                            VStack {
                                                Text("\((currentDate + TimeInterval((86400 * day))).formatted(.dateTime.day()))")
                                                    .foregroundColor(.white)
                                                Text("\((currentDate + TimeInterval((86400 * day))).formatted(.dateTime.weekday(.short)))")
                                                    .foregroundColor(.white)
                                            }
                                        }
                                    }
                                } else {
                                    Button {
                                        selectedDate = (currentDate + TimeInterval((86400 * day)))
                                        // and here
                                    } label: {
                                        ZStack {
                                            VStack {
                                                Text("\((selectedDate + TimeInterval((86400 * day))).formatted(.dateTime.day()))")
                                                    .foregroundColor(.white)
                                                Text("\((selectedDate + TimeInterval((86400 * day))).formatted(.dateTime.weekday(.short)))")
                                                    .foregroundColor(.white)
                                            }
                                        }
                                    }
                                }
                                
                                }
0

你可以尝试这种方法,保持你的逻辑,但使用currentDate.addingTimeInterval(TimeInterval((86400 * day)))

struct ContentView: View {
    @State var currentDate = Date()
    @State var selectedDate = Date()
    
    var body: some View {
        VStack {
            Text("selected day: \(selectedDate.formatted(.dateTime.day())),  \(selectedDate.formatted(.dateTime.weekday(.wide)))")
            ScrollView (.horizontal){
                HStack {
                    ForEach(0..<100) { day in
                        let theDate = currentDate.addingTimeInterval(TimeInterval((86400 * day)))
                        if (selectedDate == theDate) {
                            Button {
                                selectedDate = theDate
                            } label: {
                                VStack {
                                    Text("\(theDate.formatted(.dateTime.day()))")
                                        .foregroundColor(.green)
                                    Text("\(theDate.formatted(.dateTime.weekday(.short)))")
                                        .foregroundColor(.green)
                                }
                            }
                        } else {
                            Button {
                                selectedDate = theDate
                            } label: {
                                VStack {
                                    Text("\(theDate.formatted(.dateTime.day()))")
                                        .foregroundColor(.red)
                                    Text("\(theDate.formatted(.dateTime.weekday(.short)))")
                                        .foregroundColor(.blue)
                                }
                            }
                        }
                        
                    }
                }
            }
        }
    }
}

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(12)
文件浏览软件的后端(例如Findermac 文件资源管理器窗口 )
上一篇
Matlab显示来自函数的变量
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 81 97
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 59 78
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 61 45
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 80 65
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 82 14
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 60 36
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 18 49
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 49 97

发表评论

登录 后才能评论

评论列表(39条)