参考我之前的question,我有的3个观看次数 我这里有一个输入字段说名称,我有一个保存工具栏按钮。保存图标放在我的内容页面上,而输入字段在我的视图中。点击保存后,我想将文本框中的数据保存到XML文件中。由于我的保存点击事件位于我的内容页面中,因此无法从我的视图中输入文字。
以下是代码段:
查看页面:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection.Emit;
using System.Text;
using Xamarin.Forms;
namespace ____
{
public class View1 : ContentView
{
public static Entry txtName;
public View1()
{
//Name
Label lblName = new Label { Text = "Name", FontAttributes = FontAttributes.Bold, Style = (Style)Application.Current.Resources["LabelStyle"] };
txtName = new Entry { Style = (Style)Application.Current.Resources["entryStyle"] };
StackLayout stName = new StackLayout
{
Padding = new Thickness(10, 0, 10, 0),
Children ={
lblName,
txtName
}
};
var scrollview = new ScrollView
{
Content = new StackLayout
{
Padding = new Thickness(0, 20, 0, 20),
//VerticalOptions = LayoutOptions.StartAndExpand,
Children = {stName
}
}
};
Content = new StackLayout
{
Padding = new Thickness(0, 20, 0, 20),
VerticalOptions = LayoutOptions.StartAndExpand,
Children =
{
scrollview
}
};
}
}
}
内容页面:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection.Emit;
using System.Text;
using Xamarin.Forms;
namespace ___
{
public class Page1 : ContentPage
{
Button btnDetails, btnN, btnT;
View1 myview1, myview2, myview3;
public Page1()
{
//Primary Items
ToolbarItem Save = new ToolbarItem();
Save.Text = "Save";
Save.Clicked += OnClick_Save;
Save.Order = ToolbarItemOrder.Primary;
Save.Icon = Device.OnPlatform("Icons/save.png", "save.png", "Toolkit.Content/save.png");
ToolbarItem Cancel = new ToolbarItem();
Cancel.Text = "Cancel";
//Cancel.Clicked += OnClick_Cancel;
Cancel.Order = ToolbarItemOrder.Primary;
Cancel.Icon = Device.OnPlatform("Icons/cancel.png", "cancel.png", "Images/cancel.png");
ToolbarItems.Add(Cancel);
ToolbarItems.Add(Save);
StackLayout stHeader = new StackLayout
{
Children = {
new Label {
Text= "--------", FontAttributes=FontAttributes.Bold, FontSize=25, TextColor=Color.FromHex("#2C3E50")
}
},
HorizontalOptions = LayoutOptions.FillAndExpand,
Padding = new Thickness(10, 0, 0, 10)
};
btnDetails = new Button { Text = "Details", HorizontalOptions = LayoutOptions.FillAndExpand };
btnN = new Button { Text = "---", HorizontalOptions = LayoutOptions.FillAndExpand };
btnT = new Button { Text = "---", HorizontalOptions = LayoutOptions.FillAndExpand };
Grid objGrid = new Grid();
objGrid.RowDefinitions.Add(new RowDefinition { Height = GridLength.Auto });
objGrid.RowDefinitions.Add(new RowDefinition { Height = GridLength.Auto });
objGrid.RowDefinitions.Add(new RowDefinition { Height = new GridLength(1, GridUnitType.Star) });
//objGrid.RowDefinitions.Add( new RowDefinition { Height = GridLength.Auto });
//
objGrid.ColumnDefinitions.Add(new ColumnDefinition
{
Width = new GridLength(1, GridUnitType.Star)
});
objGrid.ColumnDefinitions.Add(new ColumnDefinition
{
Width = new GridLength(1, GridUnitType.Star)
});
objGrid.ColumnDefinitions.Add(new ColumnDefinition
{
Width = new GridLength(1, GridUnitType.Star)
});
objGrid.Children.Add(stHeader, 0, 0);
Grid.SetColumnSpan(stHeader, 3);
btnDetails.Clicked += ButtonClicked;
objGrid.Children.Add(btnDetails, 0, 1);//col, row
btnN.Clicked += ButtonClicked;
objGrid.Children.Add(btnN, 1, 1);
//btn3 = new Button { Text = "3" };
btnT.Clicked += ButtonClicked;
objGrid.Children.Add(btnT, 2, 1);
myview1 = new View1();
myview2 = new View1();
myview3 = new View1();
objGrid.Children.Add(myview1, 0, 2);
objGrid.Children.Add(myview2, 0, 2);
objGrid.Children.Add(myview3, 0, 2);
Grid.SetColumnSpan(myview1, 3);
Grid.SetColumnSpan(myview2, 3);
Grid.SetColumnSpan(myview3, 3);
Content = objGrid;
SelectButton(btnDetails);
}
private void OnClick_Save(object sender, EventArgs e)
{
var s = View1.txtName.Text;
}
void SelectButton(Button button)
{
View1 view = null;
if (button == btnDetails)
view = myview1;
if (button == btnN)
view = myview2;
if (button == btnT)
view = myview3;
myview1.IsVisible = myview1 == view;
myview2.IsVisible = myview2 == view;
myview3.IsVisible = myview3 == view;
btnDetails.TextColor = (btnDetails == button) ? Color.Accent.AddLuminosity(0.18) : (Color)Button.TextColorProperty.DefaultValue;
btnN.TextColor = (btnN == button) ? Color.Accent.AddLuminosity(0.18) : (Color)Button.TextColorProperty.DefaultValue;
btnT.TextColor = (btnT == button) ? Color.Accent.AddLuminosity(0.18) : (Color)Button.TextColorProperty.DefaultValue;
btnDetails.BackgroundColor = (btnDetails == button) ? Color.Silver.AddLuminosity(0.18) : Color.Silver.AddLuminosity(0.1);
btnN.BackgroundColor = (btnN == button) ? Color.Silver.AddLuminosity(0.18) : Color.Silver.AddLuminosity(0.1);
btnT.BackgroundColor = (btnT == button) ? Color.Silver.AddLuminosity(0.18) : Color.Silver.AddLuminosity(0.1);
}
void ButtonClicked(object sender, EventArgs e)
{
SelectButton((Button)sender);
}
}
}
如何在我的内容页面中输入文本框值保存按钮?
答案 0 :(得分:0)
您可以尝试将Entry控件公开为View1的属性 例: public Entry TextName {get {return txtName; }}
然后您的页面可以访问:
string value = myView1.TextName.Text
答案 1 :(得分:0)
使用实例成员引用而不是静态引用:
View1
班级中,将public static Entry txtName;
更改为
public Entry txtName;
。View1 _currentView;
添加到Page1
类。SelectButton()
方法结束时,添加_currentView =
view;
。OnClick_Save()
中,将var s =
View1.txtName.Text;
更改为var s = _currentView.txtName.Text;
。