繁体   English   中英

Win8 Javascript Metro App,带有C#WinRT组件和SQLite

[英]Win8 Javascript Metro App, with C# WinRT Component and SQLite

我正在创建一个Windows 8商店应用程序。 这个应用程序的前端(主项目)是HTML5 / Javascript。 我正在按照Tim Heuer的指南创建一个包含SQLite调用并充当控制器的C#WinRT组件。 前端通过Javascript调用此组件,以更新数据并获取演示文稿内容。

所以我的解决方案中有2个项目,javascript中的“main”和C#中的“db”。 我已经设法让SQLite按照指南工作了。 我有这种结构的原因是我正在尝试将应用程序从iOS移植到Win8。 “控制器”部分是一个独立的组件,它已经移植到C#。

但是,有一点需要注意。 由于这个已知问题 ,我必须从'db'项目中删除对C ++ Runtime v11的引用,以使其可编译。 虽然它在开发机器上运行良好。

然后我得到了这台测试机(三星xe700t1a确切地说是Intel i5),我发现当在这台测试机器上“调试远程”时,Visual Studio将不会部署SQLite3。 结果,我的SQLite调用失败并出现错误: "Unable to load DLL 'sqlite3': The specified module could not be found. (Exception from HRESULT: 0x8007007E)"

根据我之前提到的指南,SQLite通过WinRT扩展可用,是为了自动部署。

我想知道为什么会发生这种情况以及如何使其正确? 我也想知道这个结构中的应用程序是否存在针对Windows应用商店的任何认证问题?

我也遇到过这篇文章这篇文章暗示目前无法在WinRT组件中使用SQLite。 但现在改变现在为时已晚,如果没有混合结构,这个项目将无法实现。

我找到了解决方案。 我使用了这篇文章的提示,而且非常简单。

我要做的是在解决方案中创建另一个项目,输出类型设置为C#类库。 将引用移动到SQLite for WinRT,并将sqlite-net(nuget)包装器移动到这个新项目。 之后,我必须手动浏览sqlite-net中的类,并将所有“内部”类更改为“public”。

对于原始控制器项目,我using myclasslib;添加using myclasslib; 以便找到类定义。

显然,这种解决方法将完美无瑕地运作。 部署了SQLite3,并且没有针对缺少引用的警告。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM